我想通过JavaScript代码连接到Oracle数据库。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Connecting to Oracle using JavaScript</title>
</head>
<body>
<script language="JavaScript" type="text/javascript">
<!--
var conObj = new ActiveXObject('ADODB.Connection');
var connectionString = "Provider=OraOLEDB.Oracle;Data Source=(DESCRIPTION=(CID=GTU_APP)(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=10.119.132.175)(PORT=1521)))(CONNECT_DATA=(SID=orcl)(SERVER=DEDICATED)));User Id=mdm;Password=admin;"
conObj.Open(connectionString);
var rs = new ActiveXObject("ADODB.Recordset");
sql = "SELECT SYSDATE FROM DUAL"
rs.Open(sql, conObj);
alert(rs(0));
rs.close;
conObj.close;
//-->
</script>
</body>
</html>
我正在获取ActiveXObject未定义错误
ActiveXObject不适用于Chrome浏览器!
最佳答案
有几个问题要考虑
您需要客户端中的驱动程序来处理数据库
由于您要从客户端连接,因此您的凭据必须位于客户端。
您的数据库端口和URL必须可以通过浏览器访问
所有这些问题都意味着您的数据库将完全暴露给任何人。
为了避免某些风险,我认为最好的方法(如果您仍然想避免服务器代码)是使用oracle提供的Web服务。在Oracle文档中有几个使用SOAP和REST的示例here an example using REST。一旦创建了资源,就可以使用ajax调用该资源。为了防止浏览器在尝试执行跨源Ajax时造成的限制,应在数据库服务器中设置Access-Control-Allow-Origin标头。这样,您无需服务器代码即可访问数据库。
关于javascript - 使用JavaScript连接到Oracle数据库,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51402225/