当前位置: 首页 > 图文教程 > 网络编程 > PHP > PHP中使用ASP.NET AJAX

PHP
正确理解PHP程序编译时的错误信息
PHP开发中关于文件操作的疑难问答
PHP.MVC的模板标签系统之标签行为调度
PHP安全配置之实现安全的两个重点
用PHP+java实现自动新闻滚动窗口
PHP编程技巧:看实例学正则表达式
PHP一些常用的正则表达式
PHPUnit袖珍指南之自动测试
PHPUnit袖珍指南之PHPUnit的目的
PHPUnit袖珍指南之安装PHPUnit
PHPUnit袖珍指南之命令行测试工具
PHP中使用crypt()实现用户身份验证
用PHP+MySQL搭建聊天室
如何编译PHP源代码
安全基础:PHP后门的隐藏技巧测试报告
PHP创建和使用session cookie变量
php的curl实现get和post
PHP自动适应范围的页码分页程序
Perl处理日期时间的技巧
php直接调用文本文件内容

PHP中使用ASP.NET AJAX


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 56 ::
收藏到网摘: n/a

 借助于CodePlex上开源项目PHP for Microsoft AJAX Library的帮助,我们已经可以在PHP上使用ASP.NET AJAX的很多核心功能了。
下载安装

PHP for Microsoft AJAX Library目前仅仅处于Alpha阶段,想实际使用似乎还早了点,只能尝鲜了。

预先需求有PHP 5.2版本,且必须安装了php-json模块。

安装方法:

下载PHP for Microsoft AJAX Library并解压缩
下载Microsoft AJAX Library(http://ajax.asp.net)
在PHP Web Service代码中include一下MSAjaxService.php。
在调用该Web Service的页面中,引入MicrosoftAjax.js文件。
下面来看一个“经典”的场景:调用服务器端方法取得复杂类型。

 编写Service文件

新建一个php文件,命名为EmployeeService.php。首先写上这一句,include必要的支持代码:

require_once 'MSAjaxService.php';

然后定义一个Employee类。四个属性一目了然,不用多说:

class Employee{    public $Id;    public $Name;    public $Email;    public $Salary;     function __construct($id, $name, $email, $salary)    {        $this->Id = $id;        $this->Name = $name;        $this->Email = $email;        $this->Salary= $salary;    }}

接下来是EmployeeService类,继承与MSAjaxService.php中的MSAjaxService基类。其中定义一个方法,用来返回一个Employee对象:

class EmployeeService extends MSAjaxService{    function GetEmployee()    {return new Employee(12345, "Dflying Chen", "[email protected]", 1000);    }}

然后新建一个EmployeeService的实例,并且调用基类的ProcessRequest()方法,处理该请求:

$theService = new EmployeeService();$theService->ProcessRequest();

大功告成!

 编写调用页面

新建一个页面,php或者html均可——程序比较简单。这回我们没了ScriptManager的帮助,引入ASP.NET AJAX客户端脚本文件以及上面的这个Service只能靠手工了。注意EmployeeService.php/js可以得到该Service的客户端代理,和ASP.NET平台上的语法一样:

<head>    <title>ASP.NET AJAX On PHP Demotitle><script type="text/javascript" src="MicrosoftAjaxLibrary/MicrosoftAjax.js"><script>    "text/javascript" src="EmployeeService.php/js">script>head>

程序的UI部分很简单,按钮用来触发异步调用,

用来显示调用结果: 

 <body>    <input id="btnGetEmployee" type="button" value="Get an Employee" onclick="return btnGetEmployee_onclick()" />    <div id="resultDiv">    div>body>

在该按钮的click事件处理函数中,调用该Service,语法也和ASP.NET AJAX中一致,非常方便:

function btnGetEmployee_onclick(){    EmployeeService.GetEmployee(onSucceeded);}

在回调函数中,把得到的Employee对象显示到resultDiv中:

function onSucceeded(result){ var sb = new Sys.StringBuilder("Server returns an Employee object: ");    sb.append("Id: " + result.Id + "");    sb.append("Name: " + result.Name + "");    sb.append("Email: " + result.Email + "");    sb.append("Salary: " + result.Salary + "");     $get("resultDiv").innerHTML = sb.toString();}

大功告成!

 示例程序界面

第一次访问

点击Get an Employee按钮后