后端如何同时接收请求体与请求参数

文章讲述了在开发一个会员卡系统时,前端如何高效地向后端传递券信息、是否向所有人发券及特定收券人数据。首次提交时遇到的问题促使作者提出改进方法,即通过路径参数而非请求体来传递部分数据,保持代码逻辑清晰。
摘要由CSDN通过智能技术生成

目录

背景概括

 前端的第一次提交

改进前端提交

总结


背景概括

现在,我有一个需求,一个会员卡系统,管理员在发券的时候,可以选择向所有人发放,或者向特定卡号者发券。因此,前端需要向后端传送该券的基本信息、是否向所有人发券以及特定的收券人。其中,后端接收时,有券实体,但该券实体中不包含是否向所有人发券以及特定的收券人卡号(只有收券人的卡号)。因此,后端的接口如下:

在这个接口内,我们希望接收到了一个优惠券实体、是否向所有人发券以及特定的授权人卡号。 

 前端的第一次提交

这次提交,我采用的是普通的POST提交,具体代码如下:

 其中,我的request是进行了封装的,不过我相信,大家还是能看懂我所想表达的思想的。如果大家不能很好的理解或者想去了解我的封装的话。可以点击我的主页寻找到《微信小程序封装request请求》或者点击微信小程序封装request请求-CSDN博客前往查看。按照这种思路,最后后端的打印结果如下:

不难发现,后端并不能接收到最后的结果,其中,isAll其实也并未被接收,false只是它的默认值。

这时候,有的人或许会向coupon类中增加isAll与userAccout两个属性。 但这并不值得被提倡,因为这两个属性本来就不属于这个类。胡乱添加只会使得你的代码没有逻辑性可言。

改进前端提交

改进后的提交方式如下:

其中,isAll与userAccount不再放在请求体内,而是放在了路径内,后端的@Param() 则是在路径内去拿参数,这样就不用修改Coupon类的信息,同时也可以很方便的拿到请求参数了。因此,后端最后的输出结果如下:

从中我们不难发现, 后端已经可以正常拿到券已经是否向所有人发放券和特定收券人的卡号了。证明这样做是可行的。

总结

其实,这个问题是非常常见的,我们在提交数据的时候,不可能每次提交,后端都能有一个完整的实体将我们的数据进行包裹。而我们也不可能说,为了这多出来的一两个数据去修改后端的实体类。因此,我们使用POST请求,将大部分数据放在请求体内传送,少部分的放在请求路径中传送

如果您觉得这篇文章对您有用的话,麻烦点个赞吧,关注我,以后会更新更多前后端的相关知识。

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

易烊子豪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值