如何将php函数产给js,如何将php函数传递到js使用

项目在后端php有一些字符串处理函数,或者是字符串合法性检测类

网页前端也需要用到,不想单独编写js代码,维护起来很麻烦,也会有细小的差异可能导致新问题

我的想法是在js和php两边各编写一个统一接口,定义一套函数调用的规则,函数名和参数如何传递等等,靠json返回结果

有这些疑问:

1.听说过webservice这个词,它指的是设计思想,还是实际的php模块呢?

2.这种通过网络调用函数的办法,安全和隐私怎样保证呢?我只想被自己的项目调用

3.这种办法有网络延迟,有没有更好的解决方案呢?

4.nodejs是否可以真正的实现前后端共用代码?可以放一个示例吗?

回复讨论(解决方案)

1. webservice的定义其实很宽,其实就是一种远程调用技术。

2. 基于身份验证,同域的后端与前段交互可以基于网站本身的用户身份验证,后端与后端的交互验证实现方式就多了

3. 简单的字符串处理等函数(不是基于依赖数据查询的复杂业务的)应该同样在js实现一个,网络问题没办法解决。

4. 基于web是不可能的。

其实楼主想要实现的东西, asp.net的控件早已经实现了.

在js和php两边各编写一个统一接口,定义一套函数调用的规则,函数名和参数如何传递等等,靠json返回结果

?用??可以?一,但?查的代??是要分??js和php ?套啊

正常就是该这么做吧!

前端把敏感数据传过来,服务端处理完成返回json数据!

但是普通的字符串处理建议别放服务端,增加了服务端压力!尽量在客户端处理!

php函数不能放在js中使用,原因很简单:两者的语法规则不一样。

所以,只要两者的语法规则是一样的,那么就可相互调用,比如 nodejs 和 javascript

当然因为两者处于网络的两端,这就有了通讯的问题。好在 nodejs 天生就支持 websock 协议,通讯问题就被内部隐藏了

不过这显然不是 php 版面讨论的问题

微软一直在推耸?客户端的 B/S,所以 vs 中就出现了客户端控件这个东西(只需在服务端书写代码)

它实际上是通过 xmlhttp 组件实现了浏览器与服务器间的通讯

而这种技术就是后来炒的沸沸扬扬的 AJAX 技术

webservice 就是 WEB服务

比较奇怪的是为什么要把它单列出来。普通网站不也是 WEB服务吗?

如果 http://localhost/add.php?a=1&b=2 返回 3,称之为网页

那么 http://localhost/index.php?m=add&a=1&b=2 也返回 3,为何就称之为远程调用了呢

只使用 HTTP 的 get、post 方法的称之为网页

而使用了 HTTP 其他的如 put、delete.... 方法的就称为 REST

其实并没有必要在一些名词上纠结,只要能达到目的就可以了

php 目前提供了

XML-PRC webservice 的初级阶段

SOAP webservice 的高级阶段

但由于 json 的流行,这些东西都不吃香了

只不过因 .Net 和 Java 至今都不肯提供官方的 JSON 操作功能,一时还不能退出历史舞台

1. webservice的定义其实很宽,其实就是一种远程调用技术。

2. 基于身份验证,同域的后端与前段交互可以基于网站本身的用户身份验证,后端与后端的交互验证实现方式就多了

3. 简单的字符串处理等函数(不是基于依赖数据查询的复杂业务的)应该同样在js实现一个,网络问题没办法解决。

4. 基于web是不可能的。

其实楼主想要实现的东西, asp.net的控件早已经实现了.

2.希望能得到更具体的防止站外调用的技术实现细节

3.所以在想办法解决~ 不想js实现的原因就如主楼所说,我个人也不喜欢将同样的功能写2份代码,太别扭了

4.解决这个问题最大的阻碍是php与js语法不通,但nodejs没有,so,后者是最有可能解决的

没接触过asp.net,不知道它实现到了怎样的程度?

在js和php两边各编写一个统一接口,定义一套函数调用的规则,函数名和参数如何传递等等,靠json返回结果

?用??可以?一,但?查的代??是要分??js和php ?套啊

从逻辑上讲我觉得可以共用:传入一个字符串,判断是不是邮箱,返回布尔值,这个布尔值不管前后端都是可以利用的

正常就是该这么做吧!

前端把敏感数据传过来,服务端处理完成返回json数据!

但是普通的字符串处理建议别放服务端,增加了服务端压力!尽量在客户端处理!

嗯,服务器压力确实是提了个醒

所以想寻找更好的办法,在不占用额外请求的前提下,将php中某些功能自动移植到js

做过这么多项目,这类简单验证的代码真不会很多,而且客户端验证也有专用的库,代码不会写很多,重复的代码也不会很多。

像确认用户名存不存在这样的,客户端自己也没办法实现,就不用多考虑了.

所以想寻找更好的办法,在不占用额外请求的前提下,将php中某些功能自动移植到js

除非自己能开发一个编译器

php函数不能放在js中使用,原因很简单:两者的语法规则不一样。

所以,只要两者的语法规则是一样的,那么就可相互调用,比如 nodejs 和 javascript

当然因为两者处于网络的两端,这就有了通讯的问题。好在 nodejs 天生就支持 websock 协议,通讯问题就被内部隐藏了

不过这显然不是 php 版面讨论的问题

微软一直在推耸?客户端的 B/S,所以 vs 中就出现了客户端控件这个东西(只需在服务端书写代码)

它实际上是通过 xmlhttp 组件实现了浏览器与服务器间的通讯

而这种技术就是后来炒的沸沸扬扬的 AJAX 技术

webservice 就是 WEB服务

比较奇怪的是为什么要把它单列出来。普通网站不也是 WEB服务吗?

如果 http://localhost/add.php?a=1&b=2 返回 3,称之为网页

那么 http://localhost/index.php?m=add&a=1&b=2 也返回 3,为何就称之为远程调用了呢

只使用 HTTP 的 get、post 方法的称之为网页

而使用了 HTTP 其他的如 put、delete.... 方法的就称为 REST

其实并没有必要在一些名词上纠结,只要能达到目的就可以了

php 目前提供了

XML-PRC webservice 的初级阶段

SOAP webservice 的高级阶段

但由于 json 的流行,这些东西都不吃香了

只不过因 .Net 和 Java 至今都不肯提供官方的 JSON 操作功能,一时还不能退出历史舞台

谢谢xu大大,长了不少知识

很感兴趣为什么nodejs会火,是什么原因异军突起?

看到很多人说最大的原因就是javascript,让前端工程师毫不费力向后转

我觉得既然他们是一家子的,想实现点字符串处理,应该用不着网络通讯吧,直接本机搞定

比如html中请求一个function.js文件,实际上是nodejs原生的后端代码直接复制进去的

虽然不是本版内容也很想了解

倒是做第三方接口方面的工作时,碰到过几次soap这个词

因为sdk的存在,也能确定大概的原理,就没去查,原来都是那一套规范性质的东西~

之前做IOS端APP的同事问我,你后台是webservice吗?

我说不是啊,就像普通的网页一样,输出json串而已

nodejs的主要卖点是non-blocking I/O

要说.net java没有操作json的东西,其实php也只有 json_encode, json_decode而已。

php js ?法不同

所以判?代?要????言的。

如果每次都提交到服?器判?,服?器?力就大了。

做过这么多项目,这类简单验证的代码真不会很多,而且客户端验证也有专用的库,代码不会写很多,重复的代码也不会很多。

像确认用户名存不存在这样的,客户端自己也没办法实现,就不用多考虑了.

你说的有道理,但我在想更多的可能性:web开发的升级空间仍然很大

可能性是有的,但不应该局限于代码复制...

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值