尚硅谷谷粒学院学习笔记11-- 微信支付,课程详情页面功能完善
课程支付需求描述
课程支付说明
(1)课程分为免费课程和付费课程,如果是免费课程可以直接观看,如果是付费观看的课程,用户需下单支付后才可以观看
(2)如果是免费课程,在用户选择课程,进入到课程详情页面时候,直接显示 “立即观看”,用户点击立即观看,可以切换到播放列表进行视频播放
2、付费课程流程
(1)如果是付费课程,在用户选择课程,进入到课程详情页面时候,会显示 “立即购买”
(2)点击“立即购买”,会生成课程的订单,跳转到订单页面
(3)点击“去支付”,会跳转到支付页面,生成微信扫描的二维码
(4)使用微信扫描支付后,会跳转回到课程详情页面,同时显示“立即观看”
创建支付模块和准备
1、在service模块下创建子模块service_order
2、在service_order模块中引入依赖
3、创建支付相关的表
4、使用代码生成器生成相关代码
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import org.junit.Test;/*** @author* @since 2018/12/13*/
public class CodeGenerator {@Testpublic void run() {// 1、创建代码生成器AutoGenerator mpg = new AutoGenerator();// 2、全局配置GlobalConfig gc = new GlobalConfig();String projectPath = System.getProperty("user.dir");gc.setOutputDir("D:\\ideacode\\guli_parent\\service\\service_order" + "/src/main/java");gc.setAuthor("dyk");gc.setOpen(false); //生成后是否打开资源管理器gc.setFileOverride(false); //重新生成时文件是否覆盖//UserServiegc.setServiceName("%sService"); //去掉Service接口的首字母Igc.setIdType(IdType.ASSIGN_ID); //主键策略gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型gc.setSwagger2(true);//开启Swagger2模式mpg.setGlobalConfig(gc);// 3、数据源配置DataSourceConfig dsc = new DataSourceConfig();dsc.setUrl("jdbc:mysql://localhost:3306/gulischool?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC");dsc.setDriverName("com.mysql.cj.jdbc.Driver");dsc.setUsername("root");dsc.setPassword("123456");dsc.setDbType(DbType.MYSQL);mpg.setDataSource(dsc);// 4、包配置PackageConfig pc = new PackageConfig();pc.setModuleName("eduorder"); //模块名//包 com.atguigu.eduservicepc.setParent("com.atguigu");//包 com.atguigu.eduservice.controllerpc.setController("controller");pc.setEntity("entity");pc.setService("service");pc.setMapper("mapper");mpg.setPackageInfo(pc);// 5、策略配置StrategyConfig strategy = new StrategyConfig();strategy.setInclude("t_order","t_pay_log");strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略strategy.setTablePrefix("t" + "_"); //生成实体时去掉表前缀strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作strategy.setRestControllerStyle(true); //restful api风格控制器strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符mpg.setStrategy(strategy);// 6、执行mpg.execute();}
}
5、编写application.properties配置文件
# 服务端口
server.port=8007
# 服务名
spring.application.name=service-order# mysql数据库连接
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/gulischool?serverTimezone=GMT%2B8
spring.datasource.username=root
spring.datasource.password=123456#返回json的全局时间格式
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=GMT+8#配置mapper xml文件的路径
mybatis-plus.mapper-locations=classpath:com/atguigu/eduorder/mapper/xml/*.xml#mybatis日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl# nacos服务地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848#开启熔断机制
#feign.hystrix.enabled=true
# 设置hystrix超时时间,默认1000ms
#hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=3000
- 启动类
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
@ComponentScan(basePackages = {"com.atguigu"})
@MapperScan("com.atguigu.eduorder.mapper")
public class OrdersApplication {public static void main(String[] args) {SpringApplication.run(OrdersApplication.class, args);}
}
开发创建订单接口
注意生成订单的时候用户一定要先登录,不然会报"status 404 reading UcenterClient#getUserInfoOrder(String)"的错误
//1 生成订单的方法@PostMapping("createOrder/{courseId}")public ResultVo saveOrder(@PathVariable String courseId, HttpServletRequest request) {//创建订单,返回订单号String orderNo = orderService.createOrders(courseId, JwtUtils.getMemberIdByJwtToken(request)); //课程id和用户id返回订单idreturn ResultVo.ok().data("orderId",orderNo);}
在common_utils创建公共的实体类vo
因为在service_edu和service_order通过openfeign调用返回的是同一种类型的对象
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value="UcenterMember对象", description="会员表")
public class UcenterMemberOrder implements Serializable {private static final long serialVersionUID = 1L;@ApiModelProperty(value = "会员id")@TableId(value = "id", type = IdType.ASSIGN_ID)private String id;@ApiModelProperty(value = "微信openid")private String openid;@ApiModelProperty(value = "手机号")private String mobile;@ApiModelProperty(value = "密码")private String password;@ApiModelProperty(value = "昵称")private String nickname;@ApiModelProperty(value = "性别 1 女,2 男")private Integer sex;@ApiModelProperty(value = "年龄")private Integer age;@ApiModelProperty(value = "用户头像")private String avatar;@ApiModelProperty(value = "用户签名")private String sign;@ApiModelProperty(value = "是否禁用 1(true)已禁用, 0(false)未禁用")private Boolean isDisabled;@ApiModelProperty(value = "逻辑删除 1(true)已删除, 0(false)未删除")private Boolean isDeleted;@ApiModelProperty(value = "创建时间")@TableField(fill = FieldFill.INSERT)private Date gmtCreate;@ApiModelProperty(value = "更新时间")@TableField(fill = FieldFill.INSERT_UPDATE)private Date gmtModified;}
package com.atguigu.commonutils.ordervo;import io.swagger.annotations.ApiModelProperty;
import lombok.Data;import java.math.BigDecimal;@Data
public class CourseWebVoOrder {private String id;@ApiModelProperty(value = "课程标题")private String title;@ApiModelProperty(value = "课程销售价格,设置为0则可免费观看")private BigDecimal price;@ApiModelProperty(value = "总课时")private Integer lessonNum;@ApiModelProperty(value = "课程封面图片路径")private String cover;@ApiModelProperty(value = "销售数量")private Long buyCount;@ApiModelProperty(value = "浏览数量")private Long viewCount;@ApiModelProperty(value = "课程简介")private String description;@ApiModelProperty(value = "讲师ID")private String teacherId;@ApiModelProperty(value = "讲师姓名")private String teacherName;@ApiModelProperty(value = "讲师资历,一句话说明讲师")private String intro;@ApiModelProperty(value = "讲师头像")private String avatar;@ApiModelProperty(value = "课程一级类别ID")private String subjectLevelOneId;@ApiModelProperty(value = "类别一级名称")private String subjectLevelOne;@ApiModelProperty(value = "课程二级类别ID")private String subjectLevelTwoId;@ApiModelProperty(value = "类别二级名称")private String subjectLevelTwo;
}
在service_ucenter创建接口
(1)实现用户id获取用户信息,返回用户信息对象
//根据用户id获取用户信息@PostMapping("getUserInfoOrder/{id}")public UcenterMemberOrder getUserInfoOrder(@PathVariable String id) {UcenterMember member = memberService.getById(id);//把member对象里面值复制给UcenterMemberOrder对象UcenterMemberOrder ucenterMemberOrder = new UcenterMemberOrder();BeanUtils.copyProperties(member,ucenterMemberOrder);return ucenterMemberOrder;}
在service_edu创建接口
(1)实现根据课程id获取课程信息,返回课程信息对象
//根据课程id查询课程信息@PostMapping("getCourseInfoOrder/{id}")public CourseWebVoOrder getCourseInfoOrder(@PathVariable String id) {CourseWebVo courseInfo = courseService.getBaseCourseInfo(id);CourseWebVoOrder courseWebVoOrder = new CourseWebVoOrder();BeanUtils.copyProperties(courseInfo,courseWebVoOrder);return courseWebVoOrder;}
编写订单service
(1)在service_order模块创建接口,实现远程调用
EduClient
package com.atguigu.eduorder.client;import com.atguigu.commonutils.ordervo.CourseWebVoOrder;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;@Component
@FeignClient("service-edu")
public interface EduClient {//根据课程id查询课程信息@PostMapping("/eduservice/coursefront/getCourseInfoOrder/{id}")public CourseWebVoOrder getCourseInfoOrder(@PathVariable("id") String id);}
UcenterClient
package com.atguigu.eduorder.client;import com.atguigu.commonutils.ordervo.UcenterMemberOrder;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;@Component
@FeignClient("service-ucenter")
public interface UcenterClient {//根据用户id获取用户信息@PostMapping("/educenter/member/getUserInfoOrder/{id}")public UcenterMemberOrder getUserInfoOrder(@PathVariable("id") String id);
}
在service_order模块编写创建订单service
package com.atguigu.eduorder.service.impl;import com.atguigu.commonutils.ordervo.CourseWebVoOrder;
import com.atguigu.commonutils.ordervo.UcenterMemberOrder;
import com.atguigu.eduorder.client.EduClient;
import com.atguigu.eduorder.client.UcenterClient;
import com.atguigu.eduorder.entity.Order;
import com.atguigu.eduorder.mapper.OrderMapper;
import com.atguigu.eduorder.service.OrderService;
import com.atguigu.eduorder.utils.OrderNoUtil;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;/*** <p>* 订单 服务实现类* </p>** @author dyk* @since 2022-04-08*/
@Service
public class OrderServiceImpl extends ServiceImpl<OrderMapper, Order> implements OrderService {@Autowiredprivate EduClient eduClient;@Autowiredprivate UcenterClient ucenterClient;@Overridepublic String createOrders(String courseId, String memberId) {//通过远程调用根据用户id获取用户信息UcenterMemberOrder userInfoOrder = ucenterClient.getUserInfoOrder(memberId);//通过远程调用根据课程id获取课信息CourseWebVoOrder courseInfoOrder = eduClient.getCourseInfoOrder(courseId);//创建Order对象,向order对象里面设置需要数据Order order = new Order();order.setOrderNo(OrderNoUtil.getOrderNo());//订单号order.setCourseId(courseId); //课程idorder.setCourseTitle(courseInfoOrder.getTitle());order.setCourseCover(courseInfoOrder.getCover());order.setTeacherName(courseInfoOrder.getTeacherName());order.setTotalFee(courseInfoOrder.getPrice());order.setMemberId(memberId);order.setMobile(userInfoOrder.getMobile());order.setNickname(userInfoOrder.getNickname());order.setStatus(0); //订单状态(0:未支付 1:已支付)order.setPayType(1); //支付类型 ,微信1baseMapper.insert(order);//返回订单号return order.getOrderNo();}
}
开发获取订单接口
在订单controller创建根据id获取订单信息接口
//2 根据订单id查询订单信息@GetMapping("getOrderInfo/{orderId}")public ResultVo getOrderInfo(@PathVariable String orderId) {QueryWrapper<Order> wrapper = new QueryWrapper<>();wrapper.eq("order_no",orderId);Order order = orderService.getOne(wrapper);return ResultVo.ok().data("item",order);}
生成微信支付二维码
//生成微信支付二维码接口//参数是订单号@GetMapping("createNative/{orderNo}")public ResultVo createNative(@PathVariable String orderNo) {//返回信息,包含二维码地址,还有其他需要的信息Map map = payLogService.createNatvie(orderNo);System.out.println("****返回二维码map集合:"+map);return ResultVo.ok().data(map);}
编写service
@Overridepublic Map createNatvie(String orderNo) {try {//1 根据订单号查询订单信息QueryWrapper<Order> wrapper = new QueryWrapper<>();wrapper.eq("order_no",orderNo);Order order = orderService.getOne(wrapper);//2 使用map设置生成二维码需要参数Map m = new HashMap();m.put("appid","wx74862e0dfcf69954");m.put("mch_id", "1558950191");m.put("nonce_str", WXPayUtil.generateNonceStr());m.put("body", order.getCourseTitle()); //课程标题m.put("out_trade_no", orderNo); //订单号m.put("total_fee", order.getTotalFee().multiply(new BigDecimal("100")).longValue()+"");m.put("spbill_create_ip", "127.0.0.1");m.put("notify_url", "http://guli.shop/api/order/weixinPay/weixinNotify\n");m.put("trade_type", "NATIVE");//3 发送httpclient请求,传递参数xml格式,微信支付提供的固定的地址HttpClient client = new HttpClient("https://api.mch.weixin.qq.com/pay/unifiedorder");//设置xml格式的参数client.setXmlParam(WXPayUtil.generateSignedXml(m,"T6m9iK73b0kn9g5v426MKfHQH7X8rKwb"));client.setHttps(true);//执行post请求发送client.post();//4 得到发送请求返回结果//返回内容,是使用xml格式返回String xml = client.getContent();//把xml格式转换map集合,把map集合返回Map<String,String> resultMap = WXPayUtil.xmlToMap(xml);//最终返回数据 的封装Map map = new HashMap();map.put("out_trade_no", orderNo);map.put("course_id", order.getCourseId());map.put("total_fee", order.getTotalFee());map.put("result_code", resultMap.get("result_code")); //返回二维码操作状态码map.put("code_url", resultMap.get("code_url")); //二维码地址return map;}catch(Exception e) {throw new GuliException(20001,"生成二维码失败");}}
获取支付状态接口
//查询订单支付状态//参数:订单号,根据订单号查询 支付状态@GetMapping("queryPayStatus/{orderNo}")public ResultVo queryPayStatus(@PathVariable String orderNo) {Map<String,String> map = payLogService.queryPayStatus(orderNo);System.out.println("*****查询订单状态map集合:"+map);if(map == null) {return ResultVo.error().message("支付出错了");}//如果返回map里面不为空,通过map获取订单状态if(map.get("trade_state").equals("SUCCESS")) {//支付成功//添加记录到支付表,更新订单表订单状态payLogService.updateOrdersStatus(map);return ResultVo.ok().message("支付成功");}return ResultVo.ok().code(25000).message("支付中");}
编写service,更新订单状态
//查询订单支付状态@Overridepublic Map<String, String> queryPayStatus(String orderNo) {try {//1、封装参数Map m = new HashMap<>();m.put("appid", "wx74862e0dfcf69954");m.put("mch_id", "1558950191");m.put("out_trade_no", orderNo);m.put("nonce_str", WXPayUtil.generateNonceStr());//2 发送httpclientHttpClient client = new HttpClient("https://api.mch.weixin.qq.com/pay/orderquery");client.setXmlParam(WXPayUtil.generateSignedXml(m,"T6m9iK73b0kn9g5v426MKfHQH7X8rKwb"));client.setHttps(true);client.post();//3 得到请求返回内容String xml = client.getContent();Map<String, String> resultMap = WXPayUtil.xmlToMap(xml);//6、转成Map再返回return resultMap;}catch(Exception e) {return null;}}//添加支付记录和更新订单状态@Overridepublic void updateOrdersStatus(Map<String, String> map) {//从map获取订单号String orderNo = map.get("out_trade_no");//根据订单号查询订单信息QueryWrapper<Order> wrapper = new QueryWrapper<>();wrapper.eq("order_no",orderNo);Order order = orderService.getOne(wrapper);//更新订单表订单状态if(order.getStatus().intValue() == 1) { return; }order.setStatus(1);//1代表已经支付orderService.updateById(order);//向支付表添加支付记录PayLog payLog = new PayLog();payLog.setOrderNo(orderNo); //订单号payLog.setPayTime(new Date()); //订单完成时间payLog.setPayType(1);//支付类型 1微信payLog.setTotalFee(order.getTotalFee());//总金额(分)payLog.setTradeState(map.get("trade_state"));//支付状态payLog.setTransactionId(map.get("transaction_id")); //流水号payLog.setAttr(JSONObject.toJSONString(map));baseMapper.insert(payLog);}
订单支付前端整合
把老师课件的assets替换到原来项目的assets文件夹
修改default.vue页面
import '~/assets/css/reset.css'
import '~/assets/css/theme.css'
import '~/assets/css/global.css'
import '~/assets/css/web.css'
import '~/assets/css/base.css'
import '~/assets/css/activity_tab.css'
import '~/assets/css/bottom_rec.css'
import '~/assets/css/nice_select.css'
import '~/assets/css/order.css'
import '~/assets/css/swiper-3.3.1.min.css'
import "~/assets/css/pages-weixinpay.css"
在api文件夹下创建order.js文件
import request from '@/utils/request'export default {//生成订单createOrders(courseId) {return request({url: '/eduorder/order/createOrder/'+courseId,method: 'post'})},//根据订单id查询订单信息getOrdersInfo(id) {return request({url: '/eduorder/order/getOrderInfo/'+id,method: 'get'})},//生成二维码的方法createNatvie(orderNo) {return request({url: '/eduorder/paylog/createNative/'+orderNo,method: 'get'})},//查询订单状态的方法queryPayStatus(orderNo) {return request({url: '/eduorder/paylog/queryPayStatus/'+orderNo,method: 'get'})}
}
2、在课程详情页面中添加创建订单方法
在“立即购买”位置添加事件
//生成订单createOrders() {ordersApi.createOrders(this.courseId).then(response => {//获取返回订单号//生成订单之后,跳转订单显示页面this.$router.push({path:'/orders/'+response.data.data.orderId})})}
3、创建订单页面,显示订单信息
在pages下面创建order文件夹,创建_oid.vue页面
<template><div class="Page Confirm"><div class="Title"><h1 class="fl f18">订单确认</h1><img src="~/assets/img/cart_setp2.png" class="fr"><div class="clear"></div></div><form name="flowForm" id="flowForm" method="post" action=""><table class="GoodList"><tbody><tr><th class="name">商品</th><th class="price">原价</th><th class="priceNew">价格</th></tr></tbody><tbody><!-- <tr><td colspan="3" class="Title red f18 fb"><p>限时折扣</p></td></tr> --><tr><td colspan="3" class="teacher">讲师:{{order.teacherName}}</td></tr><tr class="good"><td class="name First"><a target="_blank" :href="'https://localhost:3000/course/'+order.courseId"><img :src="order.courseCover"></a><div class="goodInfo"><input type="hidden" class="ids ids_14502" value="14502"><a target="_blank" :href="'https://localhost:3000/course/'+ order.courseId">{{order.courseTitle}}</a></div></td><td class="price"><p>¥<strong>{{order.totalFee}}</strong></p><!-- <span class="discName red">限时8折</span> --></td><td class="red priceNew Last">¥<strong>{{order.totalFee}}</strong></td></tr><tr><td class="Billing tr" colspan="3"><div class="tr"><p>共 <strong class="red">1</strong> 件商品,合计<spanclass="red f20">¥<strong>{{order.totalFee}}</strong></span></p></div></td></tr></tbody></table><div class="Finish"><div class="fr" id="AgreeDiv"><label for="Agree"><p class="on"><input type="checkbox" checked="checked">我已阅读并同意<a href="javascript:" target="_blank">《谷粒学院购买协议》</a></p></label></div><div class="clear"></div><div class="Main fl"><div class="fl"><a :href="'/course/'+order.courseId">返回课程详情页</a></div><div class="fr"><p>共 <strong class="red">1</strong> 件商品,合计<span class="red f20">¥<strongid="AllPrice">{{order.totalFee}}</strong></span></p></div></div><input name="score" value="0" type="hidden" id="usedScore"><button class="fr redb" type="button" id="submitPay" @click="toPay()">去支付</button><div class="clear"></div></div></form></div>
</template>
调用部分
<script>
import ordersApi from '@/api/orders'
export default {asyncData({ params, error }) {return ordersApi.getOrdersInfo(params.oid).then(response => {return {order: response.data.data.item}})},methods:{//去支付toPay() {this.$router.push({path:'/pay/'+this.order.orderNo})}}
}
</script>
创建支付页面,生成二维码完成支付
在pages目录下创建pay文件夹,创建_pid.vue页面
(1)页面部分
<template><div class="cart py-container"><!--主内容--><div class="checkout py-container pay"><div class="checkout-tit"><h4 class="fl tit-txt"><span class="success-icon"></span><span class="success-info">订单提交成功,请您及时付款!订单号:{{payObj.out_trade_no}}</span></h4><span class="fr"><em class="sui-lead">应付金额:</em><em class="orange money">¥{{payObj.total_fee}}</em></span><div class="clearfix"></div></div><div class="checkout-steps"><div class="fl weixin">微信支付</div><div class="fl sao"><p class="red">请使用微信扫一扫。</p><div class="fl code"><!-- <img id="qrious" src="~/assets/img/erweima.png" alt=""> --><!-- <qriously value="weixin://wxpay/bizpayurl?pr=R7tnDpZ" :size="338"/> --><qriously :value="payObj.code_url" :size="338"/><div class="saosao"><p>请使用微信扫一扫</p><p>扫描二维码支付</p></div></div></div><div class="clearfix"></div><!-- <p><a href="pay.html" target="_blank">> 其他支付方式</a></p> --></div></div></div>
</template>
调用部分
<script>
import ordersApi from '@/api/orders'
export default {asyncData({ params, error }) {return ordersApi.createNatvie(params.pid).then(response => {return {payObj: response.data.data}})},data() {return {timer1:''}},//每隔三秒调用一次查询订单状态的方法mounted() {//页面渲染之后执行this.timer1 = setInterval(() => {this.queryOrderStatus(this.payObj.out_trade_no)},3000);},methods:{queryOrderStatus(orderNo) {ordersApi.queryPayStatus(orderNo).then(response => {if (response.data.success) {//支付成功,清除定时器clearInterval(this.timer1)//提示this.$message({type: 'success',message: '支付成功!'})//跳转回到课程详情页面this.$router.push({path: '/course/' + this.payObj.course_id})}})}}
}
</script>
课程详情页面功能完善
1、在service_order模块添加接口
根据用户id和课程id查询订单信息
//根据课程id和用户id查询订单表中订单状态@GetMapping("isBuyCourse/{courseId}/{memberId}")public boolean isBuyCourse(@PathVariable String courseId,@PathVariable String memberId) {QueryWrapper<Order> wrapper = new QueryWrapper<>();wrapper.eq("course_id",courseId);wrapper.eq("member_id",memberId);wrapper.eq("status",1);//支付状态 1代表已经支付int count = orderService.count(wrapper);if(count>0) { //已经支付return true;} else {return false;}}
2、在service_edu模块课程详情接口远程调用
(1)创建OrderClient接口
@Component
@FeignClient("service-order")
public interface OrdersClient {//根据课程id和用户id查询订单表中订单状态@GetMapping("/eduorder/order/isBuyCourse/{courseId}/{memberId}")public boolean isBuyCourse(@PathVariable("courseId") String courseId, @PathVariable("memberId") String memberId);
}
(2)在课程详情接口调用
//2 课程详情的方法@GetMapping("getFrontCourseInfo/{courseId}")public ResultVo getFrontCourseInfo(@PathVariable String courseId, HttpServletRequest request) {//根据课程id,编写sql语句查询课程信息CourseWebVo courseWebVo = courseService.getBaseCourseInfo(courseId);//根据课程id查询章节和小节List<ChapterVo> chapterVideoList = chapterService.getChapterVideoByCourseId(courseId);//根据课程id和用户id查询当前课程是否已经支付过了boolean buyCourse = ordersClient.isBuyCourse(courseId, JwtUtils.getMemberIdByJwtToken(request));return ResultVo.ok().data("courseWebVo",courseWebVo).data("chapterVideoList",chapterVideoList).data("isBuy",buyCourse);}
二、修改课程详情页面
1、页面内容修改
<section v-if="isbuy || Number(courseWebVo.price) === 0" class="c-attr-mt"><a href="#" title="立即观看" class="comm-btn c-btn-3">立即观看</a></section><section v-else class="c-attr-mt"><a @click="createOrders()" href="#" title="立即购买" class="comm-btn c-btn-3">立即购买</a></section>
2、调用方法修改
<script>
import courseApi from '@/api/course'
import ordersApi from '@/api/orders'
export default {asyncData({ params, error }) {return {courseId: params.id}},data() {return {courseWebVo: {},chapterVideoList: [],isbuy: false,}},created() {//在页面渲染之前执行this.initCourseInfo()},methods:{//查询课程详情信息initCourseInfo() {courseApi.getCourseInfo(this.courseId).then(response => {this.courseWebVo=response.data.data.courseWebVo,this.chapterVideoList=response.data.data.chapterVideoList,this.isbuy=response.data.data.isBuy})},//生成订单createOrders() {ordersApi.createOrders(this.courseId).then(response => {//获取返回订单号//生成订单之后,跳转订单显示页面this.$router.push({path:'/orders/'+response.data.data.orderId})})}}
};
</script>
如果在调用过程中出现这个错误
新建一个实现类实现那个调用接口
@Component
@FeignClient(name="service-order",fallback = OrderFeignClient.class)
public interface OrdersClient {//根据课程id和用户id查询订单表中订单状态@GetMapping("/eduorder/order/isBuyCourse/{courseId}/{memberId}")public boolean isBuyCourse(@PathVariable("courseId") String courseId, @PathVariable("memberId") String memberId);
}
@Component
public class OrderFeignClient implements OrdersClient{@Overridepublic boolean isBuyCourse(String courseId, String memberId) {return false;}
}
尚硅谷谷粒学院学习笔记11-- 微信支付,课程详情页面功能完善相关推荐
- 尚硅谷谷粒学院学习笔记(防坑点的总结部分勘误)
谷粒学院学习笔记 部分勘误 数据库设计规约 模块说明 环境搭建 创建一个Spring Boot 的父工程,版本使用:2.2.1.RELEASE 父工程pom.xml里面添加 在pom.xml中添加依赖 ...
- 尚硅谷谷粒学院学习笔记9--前台用户登录,注册,整合jwt,微信登录
用户登录业务 单点登录(Single Sign On),简称SSO. 用户只需要登陆一次就可以访问所有相互信任的应用系统 单点登录三种常见方式 session广播机制实现 使用redis+cookie ...
- 尚硅谷云原生学习笔记(1-75集)
笔记列表: 尚硅谷云原生学习笔记(1-75集) 尚硅谷云原生学习笔记(76~143集) 尚硅谷云原生学习笔记(144~172集) 尚硅谷云原生学习笔记(173~XXX集) 目录 1.什么是云计算 1. ...
- 尚硅谷云原生学习笔记(76~143集)
笔记列表: 尚硅谷云原生学习笔记(1-75集) 尚硅谷云原生学习笔记(76~143集) 尚硅谷云原生学习笔记(144~172集) 尚硅谷云原生学习笔记(173~XXX集) 目录 76.为什么用kube ...
- 尚硅谷Redis 7学习笔记
尚硅谷Redis 7学习笔记 视频链接 新手入门篇 1.安装及数据类型 2.持久化 3.Redis 7 事务.管道.发布订阅.主从.哨兵.集群 4.springboot整合redis 高级篇(更新中- ...
- Day215.课程详细页面功能完善、Echarts统计分析模块[生成统计数据+生成图表]前后端整合 -谷粒学院
谷粒学院 课程详细页面功能完善 一.修改课程详细接口 1.在service_order模块添加接口 用于判断订单中status值是否为1,为1则为已支付 @RestController @CrossO ...
- 尚硅谷谷粒学院2020 高级篇代码_尚硅谷联合KubeSphere ,共同打造企业级云原生课程!...
原作者姓名:尚硅谷教育 原出处:尚硅谷公众号 原文链接:尚硅谷联合KubeSphere ,共同打造企业级云原生课程! 近日,尚硅谷与KubeSphere 达成合作,在"大厂学院:拥抱云原生& ...
- 尚硅谷java基础学习笔记
小郑 Java基础 常用DOS命令 dir:列出当前目录下的文件以及文件夹 md:创建目录 rd: 删除目录 cd:进入指定的目录 cd- : 退回到上一级目录 cd\ : 退回到根目录 del : ...
- 尚硅谷MySQL高级学习笔记
数据库MySQL学习笔记高级篇 文章目录 数据库MySQL学习笔记高级篇 写在前面 1. mysql的架构介绍 mysql简介 概述 高级Mysql mysqlLinux版的安装 mysql配置文件 ...
最新文章
- 机器学习:多层感知机原理及实现
- POJ2594 Treasure Exploration
- IdentityServer4直播
- 小白入门机器学习必备:编程语言环境介绍及搭建
- 【Eclipse】eclipse中设置tomcat启动时候的JVM参数
- Spring Tool Suite 错误: Server Tomcat v8.0 Server at localhost was unable to start within 45 seconds.
- 有多少是长大了以后才明白的道理?
- 从零开始刷Leetcode——数组(1.26)
- No such file or directory
- 获取 app 签名的方式汇总
- AICreateMeeting-遇见未来
- php redis令牌桶,php 基于redis使用令牌桶算法实现流量控制
- 基于LSTM自动生成中文藏头诗
- 谷歌浏览器网页翻译插件
- 无线网卡无信号无服务器,无线网卡不能连接网络是什么原因?
- WSL与idea集成攻略
- 橙单微服务的权限部分之过滤规则
- 如何把阿里图标库的图标生成代码并应用于自己的项目
- Selenium基础知识 多窗口处理
- python3 selenium 自动化 登录搜狐邮箱之 函数的二次封装和模块的调用及函数的调用
热门文章
- 豆瓣FM duilib版
- 腾讯起点学院:用户增长训练营
- 来看一看那些已经倒闭的互联网公司
- 黑猫详解【UFS HCI】第1篇:UFSHCI系统框架介绍
- 《软件工具》手把手教你使用Visual Studio Code开发C/C++(Windows)
- 97岁诺奖得主的励志人生:本科学文学,博士转物理,54岁才开始锂电池研究
- GitLab - Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password)
- 下午茶界“新晋网红”:星语乐茶牛角包搭配手工茶(转载)
- EXCEL上固定表头表尾
- S300V的前世今生