PHP远程连接oracle数据库操作实现方法图文详解


Posted in PHP onApril 11, 2019

本文实例讲述了PHP远程连接oracle数据库操作实现方法。分享给大家供大家参考,具体如下:

一.以下是基于 wampServer 的php 访问oracle数据库的操作步骤:

1、第一步:让PHP支持OCI

首先,安装PHP的集成运行环境,网上有很多集成,我安装的是WampServer的(具体的安装方法也可以参考之前写的另一篇文章),安装好后,从安装目录中找到php.ini文件,比如我本地的路径是D:\wamp\bin\php\php5.3.3,将php.ini中的php_oci8.dll的;去掉,也就是把注释去掉,相当于可以使用php_oci8了。

PHP远程连接oracle数据库操作实现方法图文详解

2、第二步:然后wampserver运行后,将php>php extentions中将php_oci8打上勾

【其他的集成环境其实也是可以的,比如phpStudy,我们可以直接从php扩展的选项里打勾对应的】。

PHP远程连接oracle数据库操作实现方法图文详解

3、第三步:oracle 数据库文件配置

对于安装有Oracle客户端的PC机,可以在Oracle安装配置文件,tnsnames.ora文件,此文件路径是安装oracle的路径,比如我本机的是

F:\oracle\product\10.2.0\client_1\NETWORK\ADMIN  ,所连的192.168.1.198数据库,其中的配置详情如下(如果显示 127.0.0.1 默认为本机):

(DESCRIPTION =
  (ADDRESS_LIST =
   (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.198)(PORT = 1521))
  )
  (CONNECT_DATA =
   (SERVICE_NAME = orcl)
  )
 )

4、第四步:检测oci8是否配置成功

①.一般情况下,打开localhost即能显示 phpinfo.php界面,里面即为 php 信息。可采用 “Ctrl+F”搜索“oci”,查看是否有对应的oci模块,当然有一点php基础的完全可以直接访问自己编写的文件,记得里面加入“echo phpinfo();”即可。

②.不要高兴太早,走到这一步,至少我是查不到的对应信息的,这时可以按照网上的一些建议,把php的ext目录下的php_oci8.dll拷到system32目录下

③.最后建议重启服务,最好是重启电脑(我在测试时发现,重启服务没用,有一次是无意中 刷新出了oci扩展,所以如果操作方法没错,我建议进行重启.)

二.代码测试远程连接 orcal 数据库(建议可用自己的oracle客户端试着是否能连接对方的服务端,以保证操作的成功率)

<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2015/12/7
 * Time: 16:25
 */
echo 'ff';
//进行连接数据库的参数配置
$dbstr ="(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST =192.168.11.198)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
(INSTANCE_NAME = orcl)))";
//phpinfo();
$conn = oci_connect('scott','tiger',$dbstr);//如果去掉最后一个参数或者为“ ”,默认连接本机
$stmt = oci_parse($conn, "select * from mono");
oci_execute($stmt);
$nrows = oci_fetch_all($stmt, $results);
if ($nrows > 0) {
echo "<table border=\"1\">\n";
echo "<tr>\n";
foreach ($results as $key => $val) {
echo "<th>$key</th>\n";
}
echo "</tr>\n";
for ($i = 0; $i < $nrows; $i++) {
echo "<tr>\n";
foreach ($results as $data) {
echo "<td>$data[$i]</td>\n";
}
echo "</tr>\n";
}
echo "</table>\n";
} else {
echo "No data found<br />\n";
}
echo " $nrows Records Selected<br />\n";
oci_free_statement($stmt);
oci_close($conn);
?>

(参考网友的一点说明)

两种方式和oracle数据库建立链接

1.

$conn = oci_connect('username','password',"(DEscriptION=(ADDRESS=(PROTOCOL =TCP)(HOST=192.168.1.198)(PORT = 1521))(CONNECT_DATA =(SID=orcl)))");

2.

$conn = oci_connect('username','password','192.168.1.198/orcl');

有的时候第一种方式不行,使用第二种,里面的几个参数分别是用户名、密码、oracle服务地址,其中orcl是服务名(但在我的机器上,后者无法访问)

另外提供一种简单的测试代码,相对而言,只是测试连接情况,更为方便:

<!DOCTYPE HTML>
<html>
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  <title>php语句结束符</title>
</head>
<body>
<?php
$dbstr ="(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST =192.168.11.102)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
(INSTANCE_NAME = orcl)))";
$dbconn=oci_connect('scott','tiger',$dbstr);
if($dbconn!=false)
{
  echo "连接成功".'<br/>';
  if(OCILogOff($dbconn)==true)
  {
    echo "关闭连接成功!".'<br/>';//
  }
}
else
{
  echo "连接失败".'<br/>';
}
?>
</body>
</html>

总结提示:

使你的php支持oracle,按照以下步骤即可:
1.安装php环境,找一下appserv或者xampp,一键安装,很方便
2.把php的ext目录下的php_oci8.dll拷到system32目录下
3.修改php.ini文件中的配置,去掉  ;extention = php_oci8.dll,去掉前面的分号
4.重启apache

注意:

1.有时候你并不会注意到的一点失误会浪费很多时间,我还要提醒的是,请记得打开oracle的服务监听!!
2.请记得作为服务端的PC机,要关闭防火墙!!
3.apache的配置文件同样重要,修改httpd.conf文件,Deny——>Allow 

<Directory />
  Options FollowSymLinks
  AllowOverride None
  Order deny,allow
#  Deny from all
  Allow from all
#允许所有访问
  Satisfy all
</Directory>
<Directory />
...
...
 #  Require local
Options Indexes FollowSymLinks
#  onlineoffline tag - don't remove
  Order Deny,Allow
  Allow from all
 #  Require local
</Directory>

4.上文中一直提示的SID 或者说oracle服务器名称什么的真的好难懂,我是直接用了配置文件中所显示的名称“orcl”,这个在你安装软件时,会有一个服务名称的提醒,自己默认的orcl而已,估计些其他的名称也是可以的。网上介绍的很乱

如果不知道怎么操作,查看学习文档是最正确的选择,希望能帮到你。

有的时候第一种方式不行,使用第二种,里面的几个参数分别是用户名、密码、oracle服务地址,其中orcl是服务名。

#  Require local

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
ionCube 一款类似zend的PHP加密/解密工具
Jul 25 PHP
在WINDOWS中设置计划任务执行PHP文件的方法
Dec 19 PHP
php json转换成数组形式代码分享
Nov 10 PHP
php 升级到 5.3+ 后出现的一些错误,如 ereg(); ereg_replace(); 函数报错
Dec 07 PHP
详解WordPress开发中用于获取分类及子页面的函数用法
Jan 08 PHP
php实现转换html格式为文本格式的方法
May 16 PHP
Yii2简单实现多语言配置的方法
Jul 23 PHP
PHP里面把16进制的图片数据显示在html的img标签上(实现方法)
May 02 PHP
PHP PDO操作MySQL基础教程
Jun 05 PHP
CI框架实现创建自定义类库的方法
Dec 25 PHP
浅谈PHP array_search 和 in_array 函数效率问题
Oct 15 PHP
基于PHP实现用户登录注册功能的详细教程
Aug 04 PHP
ThinkPHP5.0框架使用build 自动生成模块操作示例
Apr 11 #PHP
PHP生成随机码的思路与方法实例探索
Apr 11 #PHP
PHP实现网站应用微信登录功能详解
Apr 11 #PHP
PHP之认识(二)关于Traits的用法详解
Apr 11 #PHP
微信公众平台开发教程⑤ 微信扫码支付模式介绍
Apr 10 #PHP
ThinkPHP框架下微信支付功能总结踩坑笔记
Apr 10 #PHP
微信公众平台开发教程④ ThinkPHP框架下微信支付功能图文详解
Apr 10 #PHP
You might like
第七节 类的静态成员 [7]
2006/10/09 PHP
PHP开发者常犯的10个MySQL错误更正剖析
2012/01/30 PHP
PHP数组循环操作详细介绍 附实例代码
2013/02/03 PHP
Symfony2实现在controller中获取url的方法
2016/03/18 PHP
PHP微信PC二维码登陆的实现思路
2017/07/13 PHP
jquery 1.4.2发布!主要是性能与API
2010/02/25 Javascript
40款非常棒的jQuery 插件和制作教程(系列二)
2011/11/02 Javascript
高性能Javascript笔记 数据的存储与访问性能优化
2012/08/02 Javascript
ajax中get和post的说明及使用与区别
2012/12/23 Javascript
Microsfot .NET Framework4.0框架 安装失败的解决方法
2013/08/14 Javascript
解析Javascript中难以理解的11个问题
2013/12/09 Javascript
js加入收藏夹代码(兼容ie/ff/op)
2014/05/16 Javascript
IE8 内存泄露(内存一直增长 )的原因及解决办法
2016/04/06 Javascript
有关JavaScript中call()和apply() 的一些理解
2016/05/20 Javascript
js实现可旋转的立方体模型
2016/10/16 Javascript
three.js加载obj模型的实例代码
2017/11/10 Javascript
vue cli2.0单页面title修改方法
2018/06/07 Javascript
JS将时间秒转换成天小时分钟秒的字符串
2019/07/10 Javascript
适合前端Vue开发童鞋的跨平台Weex的使用详解
2019/10/16 Javascript
简单使用webpack打包文件的实现
2019/10/29 Javascript
NodeJS实现一个聊天室功能
2019/11/25 NodeJs
详解webpack的clean-webpack-plugin插件报错
2020/10/16 Javascript
JS如何调用WebAssembly编译出来的.wasm文件
2020/11/05 Javascript
python画柱状图--不同颜色并显示数值的方法
2018/12/13 Python
Python计算一个点到所有点的欧式距离实现方法
2019/07/04 Python
如何在python中执行另一个py文件
2020/04/30 Python
HTML5文档结构标签
2017/04/21 HTML / CSS
西班牙太阳镜品牌:Hawkers
2018/03/11 全球购物
Expedia丹麦:全球领先的旅游网站
2018/03/18 全球购物
酒店管理专业毕业生推荐信
2013/11/10 职场文书
《开国大典》教学反思
2014/04/19 职场文书
演讲稿格式
2014/04/30 职场文书
离职报告范文
2014/11/04 职场文书
2014年大学学生会工作总结
2014/12/02 职场文书
幼儿园安全教育月活动总结
2015/05/08 职场文书
预备党员表决心的话
2015/09/22 职场文书