如何将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开发的升级空间仍然很大
可能性是有的,但不应该局限于代码复制...

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

PHP8.1中的枚舉功能通過定義命名常量增強了代碼的清晰度和類型安全性。 1)枚舉可以是整數、字符串或對象,提高了代碼可讀性和類型安全性。 2)枚舉基於類,支持面向對象特性,如遍歷和反射。 3)枚舉可用於比較和賦值,確保類型安全。 4)枚舉支持添加方法,實現複雜邏輯。 5)嚴格類型檢查和錯誤處理可避免常見錯誤。 6)枚舉減少魔法值,提升可維護性,但需注意性能優化。

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

在PHPStorm中如何進行CLI模式的調試?在使用PHPStorm進行開發時,有時我們需要在命令行界面(CLI)模式下調試PHP�...

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...
