例如:PHP连接一个mysql数据库操作的演示,
实现连接打开一个库,并读取数据的基本功能。
数据库名称为:test表名为:user
分别有7个字段:id userid sex age tel email address
服务器;数据库编码 均采用 utf-8
mysql_query("set names 'gbk'")// //这就是指定数据库字符集,一般放在连接数据库后(解决数据库乱码)
*/
?>
<HTML>
<HEAD>
<META NAME="GENERATOR" Content="Microsoft Visual Studio 6.0">
<style type="text/css">
<!--
input { font-size:9pt}
A:link {text-decoration: underlinefont-size:9ptcolor:000059}
A:visited {text-decoration: underlinefont-size:9ptcolor:000059}
A:active {text-decoration: nonefont-size:9pt}
A:hover {text-decoration:underlinecolor:red}
body,table {font-size: 9pt}
tr,td{font-size:9pt}
-->
</style>
<title>注册会员列表 - 读取mysql的测试</title>
</HEAD>
<body alink="#FF0000" link="#000099" vlink="#CC6600" topmargin="8" leftmargin="0" bgColor="#FFFFFF">
<br><br><center><font color=green size=3><b>注 册 会 员 列 表</b></font></center>
<br>
<table cellspacing=0 bordercolordark=#FFFFFF width="95%" bordercolorlight=#000000 border=1 align="center" cellpadding="2">
<tr bgcolor="#6b8ba8" style="color:FFFFFF">
<td width="5%" align="center" valign="bottom" height="19">ID</td>
<td width="10%" align="center" valign="bottom">姓名</td>
<td width="5%" align="center" valign="bottom">性别</td>
<td width="5%" align="center" valign="bottom">年龄</td>
<td width="20%" align="center" valign="bottom">联系电话</td>
<td width="20%" align="center" valign="bottom">电子邮件</td>
<td width="20%" align="center" valign="bottom">家庭住址</td>
</tr>
<?
//连接到本地mysql数据库
$myconn=mysql_connect("localhost","root","root")
//选择test为操作库
mysql_query("set names 'gbk'")// //这就是指定数据库字符集,一般放在连接数据库后面就系了
mysql_select_db("test",$myconn)
$strSql="select * from user"
//用mysql_query函数从user表里读取数据
$result=mysql_query($strSql,$myconn)
while($row=mysql_fetch_array($result))//通过循环读取数据内容
{
?>
<tr>
<td align="center" height="19"><?echo $row["id"]?></td>
<td align="center"><?echo $row["userid"]?></td>
<td align="center"><?echo $row["sex"]?></td>
<td align="center"><?echo $row["age"]?></td>
<td align="center"><?echo $row["tel"]?></td>
<td align="center"><?echo $row["email"]?></td>
<td align="center"><?echo $row["address"]?></td>
</tr>
<?
}
//关闭对数据库的连接
mysql_close($myconn)
?>
</table>
</BODY>
</HTML>
1:预定义在home目录,也可以其他任意目录,写一个文件,例如caleng_module.def
内容是你希望定义的函数名以及参数:
int a(int x,int y)
string b(string str,int n)
2:到php源码目录的ext目录
#cd /usr/local/php-5.4.0/ext/
执行命令,生成对应扩展目录
#./ext_skel --extname=caleng_module --proto=/home/hm/caleng_module.def
3:修改config.m4
去掉dnl的注释
PHP_ARG_ENABLE(caleng_module, whether to enable caleng_module support,
Make sure that the comment is aligned:
[ --enable-caleng_module Enable caleng_module support])
4:修改caleng_module.c
.代码如下:
/* {{{ proto int a(int x, int y)
*/
PHP_FUNCTION(a)
{
int argc = ZEND_NUM_ARGS()
int x
int y
int z
if (zend_parse_parameters(argc TSRMLS_CC, "ll", &x, &y) == FAILURE)
return
z=x+y
RETURN_LONG(z)
}
/* }}} */
/* {{{ proto string b(string str, int n)
*/
PHP_FUNCTION(b)
{
char *str = NULL
int argc = ZEND_NUM_ARGS()
int str_len
long n
char *result
char *ptr
int result_length
if (zend_parse_parameters(argc TSRMLS_CC, "sl", &str, &str_len, &n) == FAILURE)
return
result_length = str_len * n
result = (char *) emalloc(result_length + 1)
ptr = result
while (n--) {
memcpy(ptr, str, str_len)
ptr += str_len
}
*ptr = '\0'
RETURN_STRINGL(result, result_length, 0)
}
/* }}} */
5:生成扩展库
#cd ./caleng_module
#/usr/local/php/bin/phpize
#./configure --with-php-config=/usr/local/php/bin/php-config
#make
#make install
6:到php的对应extensions目录
如上图所示
#cd /usr/local/php/lib/php/extensions/no-debug-non-zts-20100525/
改目录下有生成的caleng_module.so文件
7:修改php.ini
php.ini如果找不到可以从phpinfo()打出的信息看到
#cd /usr/local/php/lib/
php.ini增加扩展信息
extension=caleng_module.so
8:重启Apache
# /usr/local/apache2/bin/apachectl restart
9:检查加载
/usr/local/php/bin/php -m
10:PHP调用
.代码如下:
echo a(1,2)
输出 3 就说明成功了!
=================================
下面是原文
Linux下用C开发PHP扩展
一、首先下载PHP源码包,假设源码包目录为:/software/php-5.2.13
一、首先下载PHP源码包,假设源码包目录为:/software/php-5.2.13
#>cd /software/php-5.2.13/ext
二、假设我们要开发一个名为caleng_module的扩展,该扩展包含两个函数:a--处理两个整型相加和b-处理字符串重复输出;
1、首先编写一个函数定义文件,该文件编写函数原型后缀为def,假设为:caleng_module.def
int a(int x, int y)
string b(string str, int n)
2、通过扩展骨架生成器,将在ext目录下自动建立扩展目录caleng_module
#>./ext_skel --extname=caleng_module --proto=caleng_module.def
3、修改配置文件: #>vim /software/php-5.2.13/ext/caleng_module/config.m4,将如下行的注释标签"dnl"去掉,修改后如下所示:
PHP_ARG_ENABLE(myfunctions, whether to enable myfunctions support,
Make sure that the comment is aligned:
[ --enable-myfunctions Enable myfunctions support])
4、完善函数a和b的功能: #>vim /software/php-5.2.13/ext/caleng_module/caleng_module.c
PHP_FUNCTION(a)
{
int x, y, z
int argc = ZEND_NUM_ARGS()
if (zend_parse_parameters(argc TSRMLS_CC, "ll", &x, &y) == FAILURE)
return
z = x + y
RETURN_LONG(z)
}
PHP_FUNCTION(b)
{
char *str = NULL
int argc = ZEND_NUM_ARGS()
int str_len
long n
char *result
char *ptr
int result_length
if (zend_parse_parameters(argc TSRMLS_CC, "sl", &str, &str_len, &n) == FAILURE)
return
result_length = str_len * n
result = (char *) emalloc(result_length + 1)
ptr = result
while (n--) {
memcpy(ptr, str, str_len)
ptr += str_len
}
*ptr = '\0'
RETURN_STRINGL(result, result_length, 0)
}
三、编译安装,假设php的安装目录为:/usr/localhost/webserver/php
#>cd /software/php-5.2.13/ext/caleng_module
#>/usr/localhost/webserver/php/bin/phpize
#>./configure --with-php-config=/usr/localhost/webserver/php/bin/php-config
#>make
#>make install
现在将在/usr/local/webserver/php/lib/php/extensions/no-debug-non-zts-20060613目录下生成caleng_module.so文件
在php.ini配置文件中加入: extension=caleng_module.so.
搞定收工
set_time_limit(0)//设置脚本超时时间0表示不限制
$socket
=
socket_create(AF_INET,
SOCK_STREAM,SOL_TCP)
//创建一个套接字,参数太多,自己查手册
socket_bind($socket,'localhost',80)
绑定主机,端口
socket_listen($socket)
监听端口
$connection=socket_accept($socket)
接受连接
后面就可以通过socket_read()和socket_write()进行收发数据
最后用socket_close()销毁资源
注意,这里需要直接通过php.exe直接来驱动,不要过服务器
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)