爆肝怒赞,不会也会了,VFPBS用Form调用webapi和文件上传

我一直教技术,今天占用大家一点时间,来说说心态的问题。
《那些年,我们一起追过的女孩》里,柯景腾说:“十年后,我可能连log是什么都不知道,但我还是可以活得好好的。”

沈佳宜点头说:“的确。”

柯景腾问她:“那你为什么知道这个道理还那么用功读书?”

沈佳宜回答说:“这个世界上本来就有很多事情是徒劳无功的啊。”

码代码跟写文章一样,很多时候,都是徒劳无功的。学VFP的人,很多人目标根本不是当一位程序员,也没有想过要靠它赚钱,没想过凭借它出人头地。

但代码可以打通到元宇宙的一条路,你产出的代码是在真实世界中运行,在元宇宙里面永生。此时无论是你的内心,还是你的外在,都可以获得一种近乎神奇的体验。

每天看一点技术相关,敲一敲代码,找出真实世界与元宇宙的连接点,我想很多事情开始变得不一样了。

永远保持对未知世界的好奇心,用VFP混合一切。

我们前面学过了用浏览器地址栏调用webapi(Get方式),也学习了用POSTMAN来调用webapi(POST方式),没看过的,翻翻加菲猫前面的文章,再不清楚的,可以加我微信来问我。

那我们的网页可以用POST方式调用webapi吗?

答案是肯定的

form提交数据到webapi

打开HBULIDX,新建一个网页,在HTML的BODY中输出如下代码,保存到框架的wwwroot目录。

<form action="a3post.fsp?proc=PostParams" method="post">
<input name="name" value="张三">
<input name="age" value="20">
<input type="submit" value="提交">
</form>

效果如下图

action很关键为提交的webapi网址, method为提交的类型post,当然也可以写成GET
这里的POST提交的参数不会在地址栏出现,而GET将会在地址栏出现。
这是web1.0时代的技术,现在是web2.0同样也是离不开1.0本质,学东西一定要先学本质,不要被花式迷了眼。

后端用VFP的webapi接收

Define Class a3post As Session
    *--接受发过来的POST所有数据 并返回去 POSTMAN是UTF8编码发过来,回发要加strconv(str,11)
	Procedure Post
	LOCAL cPostData
	cPostData=HttpGetPostData(this.iconnid)
	RETURN cPostData  
	Endproc
   
    *--解析键值对格式 name=张三&age=21
    Procedure PostParams
    LOCAL cname,cage
    cname=httpqueryparams("name",this.iconnid)
    cage=httpqueryparams("age",this.iconnid)
    RETURN "姓名:"+cname+"年龄:"+cage  
	Endproc
enddefine

浏览器输入
http://192.168.0.99:801/form.html
如果你有配置了内网穿透,就可以用内网穿透的域名访问。
http://qiyusoft.free.idcfengye.com/form.html
可以看到执行结果如下图。

form进行文件上传

1 编写HTML前端页面,文件名fileupload.html存放在WWWROOT目录下,

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <body>
    <form action="ctl_file.fsp" method="post" enctype="multipart/form-data">
      <input type="text" name="ttt" value="">
      <input type="file" name="myfile">
      <input type="submit" value="保存"/>
    </form>
  </body>
</html>

代码解析:
1 form表单的action指向了VFP后端的ctl_file类,也就是这个表单的内容会被ctl_file类所接收。

2 enctype参数multipart/form-data表示表单由键值对提交的方式,改成文件上传模式。

3 在 HTML 文档中

 <input type="file"> 

标签每出现一次,一个 FileUpload文件 对象就会被创建。 它包含一个文本输入字段,用来输入文件名,还有一个按钮,用来打开文件选择对话框选择文件。

如果要过滤指定后缀的文件,添加accept属性,如只能选择rar文件

<input class="style_file_content" accept=".rar" type="file" />

  切记:value属性不要写,name的值是给后端用的

2 编写VFP后端代码

Define Class ctl_file As Session
  Procedure ondefault
      clear
    oFile=getupfile()
    ?"ttt的值",oFile.oFieldColl.Item("ttt").fielddata
    ?"上传文件名",oFile.oFieldColl.Item("myfile").filename
    *--文件数据
    cFileData=oFile.oFieldColl.Item("myfile").fielddata
    *--文件保存起来
    STRTOFILE(cFileData,getwwwrootpath()+"1.rar")
  return "ok"
  Endproc
Enddefine

代码解析:
 HTML前端FORM是文件上传模式,所以我们利用getupfile()来接收,它会返个文件对象,包含了一个集合,每个集合的KEY就是前端传入的name字段。

结构:oFieldColl集合,item(key)是个对像存放每个字段的相关内容。集合的key=前端的name

 oFieldColl.item(key).FieldName:字段名 (前端传入的name)

oFieldColl.item(key).FieldData: 字段值(前端传入的value)

 oFieldColl.item(key).FileName: 文件名,如果上传的是文件类型,这里可以获取原始文件名。

 oFieldColl.item(key).FieldType:字段类型

getwwwrootpath的作用指向wwwroot目录,编译之后,就是网站根目录。

可以看到VFP有输出了

查看wwwroot目录

在公众号中使用我们的网页

1 这个网址可以放到菜单栏里
2 也可以用消息回复或发送给用户

{
    "touser":"oH69RwCyPr8uQxBFHfyaYurvQ8Mk",
    "msgtype":"text",
    "text":
    {
         "content":"<a href='http://qiyusoft.free.idcfengye.com/form.html'>提交数据</a>"
    }
}

总结

1 form表单一般情况用键值对提交,用HttpQueryParams接收
2 form表单要做文件上传,method="post" enctype="multipart/form-data",后端接收用GetUpfile来接收。

posted @ 2021-11-23 09:04  加菲猫的VFP  阅读(309)  评论(0编辑  收藏  举报