前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >VFP也可以做前端,猫猫走过无数的弯路,才总结出这篇BS入门

VFP也可以做前端,猫猫走过无数的弯路,才总结出这篇BS入门

作者头像
加菲猫的VFP
发布2021-11-19 14:51:04
9100
发布2021-11-19 14:51:04
举报
文章被收录于专栏:加菲猫的VFP

调试服务器使用

打开框架项目文件 运行 环境设置.prg 运行调试服务器即可启动。 默认端口为801,IP为开发机器所在的IP

测试调试服务器

打开好调试服务器,就可以打开浏览器(推荐 使用360极速,谷歌浏览器) 输入http://192.168.0.99:801/1.fsp 根据开发机器修改IP 同台机器也可用127.0.0.1

出现如上的字样表示调试服务器工作良好。

网址URL和开发框架的一些约定

http://192.168.0.99:801/a1send.fsp?proc=Send 192.168.0.99为IP地址,如果有域名可以换成域名 801为HTTP服务端口 1.Fsp 使用FSP做为调用文件名,调用a1send.prg中的 a1send类 proc=Send参数调用a1send类的方法

编写一个控制器类

控制器类是与BS前端交互的接口类

A1send类的定义

代码语言:javascript
复制
Define Class a1send As Session
  Procedure Send
  Return "Hello world"
  Endproc
Enddefine

调用时浏览器输入 http://127.0.0.1:801/a1send.fsp?proc=sendJson 就可以看到输出JSON了。 也可以使用POSTMAN来测试。

服务器接收GET传参

*-- WebApi 控制器类 *-- 规范:文件名跟类名是一样的.如类名:1Send,文件名1Send.prg *-- 调用格式 http://ip:端口号/类名.fsp?proc=类过程名 *-- http传参 get方式传参 在url中进行拼接 *-- 用&键=值对来传值,可多个拼接 http://ip:端口号/类名.fsp?proc=类过程名&参数1=参数值

代码语言:javascript
复制
Define Class a2get As Session
    *--传参 key1=test 
    Procedure get
    cResult=httpqueryparams("key1",this.iconnid)
    cResult1=httpqueryparams("key2",this.iconnid)
    RETURN "您传的参数是:"+cResult+cResult1
    ENDPROC

Enddefine

调用时浏览器输入 http://127.0.0.1:801/a2get.fsp?proc=get&key1=test&key2=123 第一个键值对参数用?连接,第二个以后用&连接。 也可以使用POSTMAN来测试。

POST 传参的说明

BS参数的传递有传键值对,有传JSON和其它格式。 放在URL(GET方式)中只能用键值对传参。 POST方式放在Body中可以发送JSON,键值对和其它格式。

键值对格式的接收

VFP后端统一用HttpQueryParams接收

JSON或其他格式

用HttpGetPostData原样接收,自行解析。

服务器接收Post传参

以下代码放在a3post的控制器类中,接受发过来的POST所有数据 并返回去

代码语言:javascript
复制
Procedure Post
    LOCAL cPostData
    cPostData=HttpGetPostData(this.iconnid)
    RETURN cPostData  
Endproc

   *--解析键值对格式 name=张三&age=21
  Procedure PostParams
    LOCAL cname,cage
    cname=httpqueryparams("name")
    cage=httpqueryparams("age")
    RETURN "姓名:"+cname+"年龄:"+cage  
Endproc

因为浏览器地址栏里面是没有办法进行POST测试的,所以我们使用POSTMAN工具来辅助测试。

如上图所示,输入URL和参数之后,按Send按键就可以测试了。

VFP作为前端调用后端的控制器类

准备工作 1 客户端项目与服务端项目要分开不同的文件夹 2 用两个VFP分别打开相应的项目 3 客户端首先运行环境设置,再运行调试服务器后关掉调试服务器 4 服务 端首先运行环境设置,再运行调试服务器 不关 

VFP客户端用Get方式传参

代码语言:javascript
复制
cUrl="http://127.0.0.1:801/a2get.fsp?proc=get"+"&key1="+"12345"
WebClient=Newobject("Qiyu_HttpClient","Qiyu_HttpClient.prg")
cData=WebClient.send(cUrl)
If !Isnull(cData)
    Messagebox(cData,11)
Else
    Messagebox(WebClient.msg)
Endif

VFP客户端用POST方式传参

Post传参可以直接加上URL中传,也可以放在Post(URL,键值对)

代码语言:javascript
复制
cUrl="http://127.0.0.1:801/a3post.fsp?proc=PostParams"
WebClient=Newobject("Qiyu_HttpClient","Qiyu_HttpClient.prg")
WebClient.method="post"
WebClient.setHeader("content-type","application/x-www-form-urlencoded") &&键值对形式提交
cData=WebClient.send(cUrl,"name=张三&age=21")
If !Isnull(cData)
    Messagebox(cData)
Else
    Messagebox(WebClient.msg)
Endif

祺佑框架JSON格式约定

成功 (串内也可以放其它信息) {" errno " :0, " errmsg " : " ok "} 失败 { “errno”: 1, “errmsg”:”错误信息”}

举例 { "errno": 1, "errmsg": "文件 '1.prg' 不存在。", "success": "false", "errorMsg": "文件 '1.prg' 不存在。,过程:socketweb1._onread,行号:171", "total ": 0, "rows": "\"192.168.0.99:801 \"" }

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-11-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 加菲猫的VFP 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 测试调试服务器
  • 网址URL和开发框架的一些约定
  • 编写一个控制器类
  • 服务器接收GET传参
  • POST 传参的说明
    • 键值对格式的接收
      • JSON或其他格式
      • 服务器接收Post传参
      • VFP作为前端调用后端的控制器类
      • VFP客户端用Get方式传参
      • VFP客户端用POST方式传参
      • 祺佑框架JSON格式约定
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档