Day24-26 项目练习(图书商城)

图书商城

环境搭建

  1. 导入原型

  • 用户模块
  • 分类模块
  • 图书模块
  • 购物车模块
  • 订单模块

?

2 功能分析

  • 前台

    • 用户模块:

      • 注册
      • 激活
      • 登录
      • 退出
    • 分类模块:

      • 查看所有分类
    • 图书模块:

      • 查询所有图书
      • 按分类查询图书
      • 查询图书详细(按id查)
    • 购物车模块:

      • 添加购物车条目;
      • 清空所有条目;
      • 删除指定条目;
      • 我的购物车(按用户查询购物车)
    • 订单模块:

      • 生成订单;
      • 我的订单(按用户查询订单)
      • 按id查询订单
      • 确认收货
      • 付款功能(只是跳转到银行页面)
      • 付款回调功能(由银行来调用我们这个方法,表示用户已经付款成功)
  • 后台:

    • 管理员:

      • 登录
    • 分类管理:

      • 添加分类
      • 查看所有分类
      • 删除分类
      • 按id查询
      • 修改分类
    • 图书管理(我的)

      • 查看所有图书
      • 按id查询
      • 删除图书
      • 修改图书
      • 添加图书(上传图片)
    • 订单模块

      • 查询所有订单
      • 按状态查询订单
      • 发货

3 框架的搭建

  1. 导包

  • 数据库:

    • mysql驱动
    • c3p0(jar包和配置文件)
    • dbutils
    • itcast-tools

      • commons-beanutils
      • commons-logging
  • javamail

    • mail.jar
    • activation.jar
  • 上传

    • commons-fileupload
    • commons-io
  • ajax

    • json-lib
  1. 创建package

  • 根:cn.itcast.bookstore

    • user

      • domain
      • dao
      • service
      • web.servlet
    • category

      • domain
      • dao
      • service
      • web.servlet
    • book

      • domain
      • dao
      • service
      • web.servlet
    • cart

      • domain
      • web.servlet
    • order

      • domain
      • dao
      • service
      • web.servlet

?

3.3 表

  • tb_user
  • category
  • book
  • orders
  • orderitem

?

用户模块

?

1 用户模块的相关类创建

  • domain:User
  • dao:UserDao
  • service:UserDao
  • web.servlet:UserServlet

2 用户注册

流程:/jsps/user/regist.jsp à UserServlet#regist() à msg.jsp

页面:

  • regist.jsp

    • 表面页面,请求UserServlet#regist()方法
    • 参数:整个表单数据
  • msg.jsp

Servlet:

  • UserServlet#regist()

    • 一键封装表单数据到User form对象
    • 补全:uid、激活码
    • 输入校验:

      • 保存错误信息到request
      • 保存当前表单数据(form)到request(回显);
      • 转发回到regist.jsp
    • 调用service的regist()方法,传递form过去;

      • 如果抛出异常:保存错误信息(异常信息)、保存表单数据(回显)、转发到regist.jsp
      • 如果没有抛出异常:

        • 发邮件(发件人、收件人、标题、内容),内容中包含超链接,超链接指向可完成激活的Servlet地址!链接中要有激活码参数!
        • 保存成功信息到request中
        • 转发到msg.jsp

Service:

  • UserService#regist(User form)

    • 校验用户是否被注册,如果注册,抛出UserException;
    • 校验邮箱是否被注册,如果注册,抛出UserException;
    • 把user插入到数据库中

Dao:

  • User findByUsername(String username):按用户名查询用户
  • User findByEmail(String email):按emal查询用户
  • void add(User form):插入用户到数据库中

?

3 用户激活

流程:用户的邮件中 à UserServlet#active() à msg.jsp

?

?

4 用户登录

流程:/jsps/user/login.jsp à UserServlet#login() à index.jsp

5 用户退出

流程:top.jsp à UserServlet#quit() à login.jsp

quit():把session销毁!

?

分类模块

?

1 分类模块的相关类创建

  • cn.itcast.bookstore.category

    • domain:Category
    • dao:CategoryDao
    • service:CategoryService
    • web.servlet:CategoryServlet

?

2 查询所有分类

  流程:main.jsp(<iframe>) à CategoryService#findAll() à left.jsp

?

图书模块

?

1 创建相关类

  • cn.itcast.bookstore.book

    • domain:Book
    • dao:BookDao
    • service :BookService
    • web.servle:BookServlet

?

?

2 查询所有图书

流程:left.jsp(全部分类) à BookServlet#findAll() à /jsps/book/list.jsp

?

3 按分类查询图书

流程:left.jsp à BookServlet#findByCategory() à list.jsp

?

?

?

4 查询详细信息(加载)

  流程:list.jsp(点击某一本书) à BookServlet#load() à desc.jsp

?

购物车模块

?

购物车存储:

  • 保存在session中
  • 保存在cookie中;
  • 保存在数据库中。

?

1 创建相关类

  • 购物车的结构:

    • CartItem:包含图书和数量
    • Cart:包含一个Map<String,CartItem>
  • dao:没有
  • service:没有
  • web.servlet:提供!CartServlet

?

  修改登录方法,在用户登录成功后,马上在session中添加一辆车!!!

?

页面:/jsps/cart/list.jsp

它只有一个任务,就是遍历车!

车在session中,通过车可以得到所有的CartItem

${sessionScope.cart.cartItems}

?

2 添加购物车条目

?

3 清空条目

?

4 删除购物车条目

?

5 我的购物车

top.jsp中存在一个链接:我的购物车

我的购物车直接访问/jsps/cart/list.jsp,它会显示session中车的所有条目

?

订单模块

?

1 创建相关类

  • domain:

    • Order
    • OrderItem
  • dao:OrderDao
  • service:OrderService
  • web.servlete:OrderServlet

?

2 生成订单

?

3 我的订单(按用户查)

?

4 加载订单(按id查)

?

5 确认收货

?

易宝支付

在线支付的两种形式:

  1. 电商与银行直连!
  • 安全
  • 不收手续费
  • 不与小电商合作!

?

  1. 第三台支付平台
  • 支付宝
  • 易宝
  • 财富通

好处:

  • 不安全
  • 收手续费(1%)
  • 小电商可以与其合作!

?

需要在第三方注册账户

  • 需要认证!
  • 我们有一个易宝的测试账户

    • 钱转过去就要不回来了!

?

易宝支付

1 去银行

  • 易宝给了我们一个网址(支付网关),重定向到这个地址即可!
  • 还需要给这个地址后添加13+1个参数!

https://www.yeepay.com/app-merchant-proxy/node?p0_Cmd=Buy&p1_MerId=10001126856&p2_Order=123456&p3_Amt=1234.56&p4_Cur=CNY&p5_Pid=&p6_Pcat=&p7_Pdesc=&p8_Url=http://localhost:8080/bookstore/OrderServlet?method=back&p9_SAF=&pa_MP=&pd_FrpId= ICBC-NET-B2C&pr_NeedResponse=1&hmac=dd17580a3ca176ba62d6d348583ba88b

?

  • 易宝回调:

    • 点对点:易宝直接访问电商,这里没有客户端什么事了。

      • 这种方式是必须要使用的,我们这种方式是收不到的!因为我们没有固定IP
      • 易宝有一个重发机制,如果它访问你,你不给它回信息,它会一直重发!
      • 电商需要返回一个以SUCCESS开头的字符串即可!
    • 引导客户端浏览器重定向到电商。是让客户端访问电商!

      • 可以不使用的!

?

  • hmac:13参数值+keyValue(密钥) + 算法(md5)

    • 13参数值:自己设置的!
    • keyValue:易宝在我们注册后发给我们的,这个东东只有我们和易宝知道!
    • 底层为md5的算法:PaymentUtil.buildHmac(14个),它返回hmac

?

?

6 支付(去银行)

  • 重定向!

    • 13+1个参数!

7 支付(银行回馈)

  • 校验访问者是否为易宝

    • 修改订单的状态

?

?

后台

后台的内容,必须要设置权限!

用户可以访问一个网站的哪些内容?

  • dao:不行
  • service:不行
  • servlet:能!
  • jsp:能!

  用户可以访问的只有WEB层!

?

1 分类管理

  • 分类管理:

    • 添加分类
    • 查看所有分类
    • 删除分类
    • 按id查询
    • 修改分类

1.1 相关类创建

  • domain:Category
  • dao:CategoryDao
  • service:CategoryService
  • admin.web.servlet:AdminCategoryServlet(为管理员提供单独的Servlet,然后给这个Servlet添加过滤器!)

1.2 查看所有分类

  • left.jsp上的菜单修改一下指向:AdminCategoryServlet#findAll()
  • findAll():

    • 调用service得到所有的分类List<Category>
    • 保存到request域,转发到/adminjsps/admin/category/list.jsp
  • list.jsp:修改页面,显示所有分类!

?

1.3 添加分类

  • add.jsp(表单页面)à
  • AdminCatetgoryServlet#add():

    • 封装表单数据;
    • 补全:cid
    • 调用service方法完成添加工作
    • 调用findAll()方法
  • service#add(Category c):略
  • dao#add(Catetgory c):略

?

1.4 删除分类

  • list.jsp(删除链接) à
  • AdminCategoryServlet#delete()

    • 获取参数:cid
    • 调用service方法完成删除!

      • 如果出现异常,保存异常信息,转发到msg.jsp显示
    • 调用findAll()
  • service#delete(String cid):

    • 通过cid查看该分类下的图书本数,如果大于0,抛出异常;
    • 如果等于0,删除该分类;

1.5 修改分类

修改分为两步:1、加载分类, 2、修改分类

第一步:加载分类

  • list.jsp(修改链接) à
  • AdminCategoryServlet#editPre()

    • 获取cid
    • 通过cid来调用service方法,得到Category对象
    • 保存到request域中,转发到mod.jsp
  • mod.jsp:把当前的Category对象显示到表单中

第二步:修改分类

  • mod.jsp(提交表单)à
  • AdminCategoryServlet#edit()

    • 封装表单数据
    • 调用service方法完成修改工作
    • 调用findAll()

?

?

2 图书管理

  • 图书管理(我的)

    • 查看所有图书
    • 按id查询
    • 删除图书
    • 修改图书
    • 添加图书(上传图片)

2.1 相关类创建

  • web.servlet.admin:

    • AdminBookServlet;
    • AdminAddBookServlet(添加图书,包含上传):上传不能使用BaseServlet,因为BaseServlet中需要使用getParameter()方法,而上传getParameter()方法就不能再使用了。

2.2 查询所有图书

  • left.jsp(菜单项(查看图书链接))à
  • AdminBookServlet#findAll()

    • 查询所有图书,保存到request
    • 转发到/adminjsps/admin/book/list.jsp
  • list.jsp:循环遍历所有图书

2.3 加载图书

  • list.jsp(点击图名或图片) à
  • AdminBookServlet#load()

    • 获取bid,通过bid调用BookService方法得到Book对象
    • 保存到request中,转发到/adminjsps/admin/book/desc.jsp
  • desc.jsp:把当前book对象显示到表单中

?

2.4 添加图书

添加图书分两步:

  1. 加载所有分类,到add.jsp中显示!
  • left.jsp(菜单项:添加图书) à
  • AdminBookServlet#addPre():

    • 查询所有分类,保存到request域,转发到add.jsp
  • 在add.jsp中循环遍历所有分类,显示在<select>中

?

  1. 添加图书
  • 上传三步:

    • 创建工厂
    • 创建解析器
    • 解析request得到表单字段!
  • 把表单字段封装到Book对象中
  • 保存上传文件,把保存的路径设置给Book的image属性。
  • 调用service方法保存Book对象到数据库中
  • 调用findAll()

?

2.5 删除图书

book表与orderitem有关联关系!

删除图书不是真的数据库表中删除记录,而是给book表添加一个del字段,它是booleanod类型,表示是否已删除!

没有被删除的图书,该列的值为false,否则为true

处理问题:

  • 修改BookDao:所有与查询相关的方法,都需要添加where条件,即del=false
  • 修改Book类,添加del属性!

?

删除图书:其实就是把表的del列修改为true!

?

  • desc.jsp(del按钮) à
  • AdminBookServlet#del()

    • 获取bid
    • 调用service方法完成删除
    • 返回列表,即调用findAll()

?

2.6 编辑图书
  • dsec.jsp(编辑按钮) à
  • AdminBookServlet#edit()

    • 封装表单数据(必须让页面保证把image传递过来)

      • 要求页面必须添加一个隐藏字段,把原来的图片路径传递过来!
    • 调用service方法完成删除
    • return findAll()

?

?

易宝支付api介绍:

1 在线支付概述

什么是在线支付呢?没错,就是在网上花钱!大家一定有过这样的经历。但是你可能不太了解在线支付的"内情",下面我们来了解一下!

如果你现在开始经营一个电子商务网站,用户买了东西一定要支付,你的网站一定要可以连接各大银行了,然后在各大银行支付完成后,再返回到你的网站上显示"支付成功"!

这就是今天我们要做的事情,连接银行的网银系统完成支付。说专业一点,我们称之为"开发在线支付的网关"

?

2 两种在线支付的方式

在线支付一共有两种方式:

  • 电商直接与银行对接;
  • 电商通过第三方支付平台与银行对接;

?

电商直接与银行对接,这也要银行同意才行,但可惜的是,银行很"牛",不是谁想与它对接都可以的。如果你的电商每日的资金流量够大,那么银行会和你对接,因为客户支付给电商的钱都存到了银行的帐户中!但是如果资金流量小,银行不会理你的!

?

当小网站资金量不足时,不能与银行对接,那么它们会选择与第三方支付公司合作。大家也都明白这是些什么公司,例如:支付宝、易宝、财富通、快钱等公司是国内比较有名的。它们这些公司可以与银行对接(因为资金够多),然后小电商与它们对接!但是第三方是要求收费的!第三方一般会收取电商1%的费用,不过不会收客户的钱。

?

?

通过上图大家可以了解到,在银行的页面上会显示出商城名称、RMB订单号、订单时间。。。,这些东西银行是怎么知道的,当然是电商传递给银行的。当电商与银行对接后,电商要给银行的页面传递银行页面需要的参数,所以银行的页面才能显示这些数据!

但是,我们的商城不能只可以对接一家银行吧!怎么也要对接BOC、CCB、ABC、ICBC四家吧!不同的银行需要的对接参数是不相同的,这说明我们在开发时要为不同的银行写不同的对接代码。这也是直接与银行对接的缺点!当然与银行直接对接也有好处,就是安全,没有手续费!

  • 为不同的银行开发不同的代码(缺点);
  • 安全(优点);
  • 没有手续费(优点);
  • 小电商银行不让对接(缺点)。

?

?

?

  上图中已经说明,客户在电商的网站上点击确认支付后,会定向到第三方的网站,然后再由第三方与银行对接。这说明电商要传递给第三方参数!再由第三方把参数传递给银行。这种方式的好处是:只需要针对第三方开发即可,而不用再为每家银行提供参数。为每家银行提供参数的工作是第三方的任务了。但是,第三方不老可靠的,如果第三方倒闭了,人跑了,那你的钱就没了。因为客户支付的钱没有到你的银行帐户中,而是支付到了第三方的银行帐户中,而你是在第三方有一个帐户。而且第三方还要收手续费,一般是1%,这可不是小数字啊(真黑)。

?

3 通过第三方在线支付规则

电商想在第三方注册商户,需要向第三方提供ICP认证。ICP经营许可证是根据国家《互联网管理办法规定》,经营性网站必须办理的网站经营许可证,没有就属于非法经营。

我们不可能因为练习就去办理ICP!所以我们无法在第三方注册商户。不过我们已经有现成的在易宝注册的商户,所以这一步就可以忽略了。

当你在易宝注册成功后,易宝会给你如下几样东西:

  • 在易宝的开户账号(即商户编码):10001126856;
  • 易宝接入规范:一个chm文件;
  • 对称加密算法类:PaymentUtil.java;
  • 密钥:69cl522AV6q613Ii4W6u8K6XuW8vM1N6bFgyv769220IuYe9u37N4y7rI4Pl。

?

在易宝接入规范中,我们可以查找到易宝的支付网关,其实就是一个URL,用来与易宝对接的一个网址:https://www.yeepay.com/app-merchant-proxy/node

在易宝接入规范中,还可以查找到易宝要求的参数,在电商与易宝对接时需要给支付网关传递这些参数:


正式请求地址:https://www.yeepay.com/app-merchant-proxy/node


?参数名称


?参数含义


是否必填


?参数长度


?参数说明


?签名顺序


?p0_Cmd


?业务类型



?Max(20)


?固定值"Buy" .


1


?p1_MerId


?商户编号



?Max(11)


商户在易宝支付系统的唯一身份标识.获取方式见"如何获得商户编号"


2


?p2_Order


?商户订单号



?Max(50)


若不为"",提交的订单号必须在自身账户交易中唯一;为 ""
时,易宝支付会自动生成随机的商户订单号.易宝支付系统中对于已付或者撤销的订单,商户端不能重复提交。


3


?p3_Amt


?支付金额



?Max(20)


?单位:元,精确到分.此参数为空则无法直连(如直连会报错:抱歉,交易金额太小。),必须到易宝网关让消费者输入金额


4


?p4_Cur


?交易币种



?Max(10)


?固定值 "CNY".


5


?p5_Pid


?商品名称



?Max(20)


用于支付时显示在易宝支付网关左侧的订单产品信息.此参数如用到中文,请注意转码.


6


?p6_Pcat


?商品种类



?Max(20)


?商品种类.
?此参数如用到中文,请注意转码.


7


?p7_Pdesc


?商品描述



?Max(20)


?商品描述.
?此参数如用到中文,请注意转码.


8


?p8_Url


?商户接收支付成功数据的地址



?Max(200)


支付成功后易宝支付会向该地址发送两次成功通知,该地址可以带参数,如:
" www.yeepay.com/callback.action?test=test".
注意:如不填p8_Url的参数值支付成功后您将得不到支付成功的通知。


9


?p9_SAF


?送货地址



?Max(1)


为"1": 需要用户将送货地址留在易宝支付系统;为"0": 不需要,默认为 "0".


10


?pa_MP


?商户扩展信息



?Max(200)


?返回时原样返回,此参数如用到中文,请注意转码.


11


?pd_FrpId


?支付通道编码



?Max(50)


默认为 "" ,到易宝支付网关.
若不需显示易宝支付的页面,直接跳转到各银行、
神州行支付、骏网一卡通等支付页面,
该字段可依照附录:支付通道编码列表 设置参数值.如果此值设置错误则会报"error.noAvaliableFrp"错误


12


?pr_NeedResponse


?应答机制



?Max(1)


固定值为"1": 需要应答机制; 收到易宝支付服务器点对点支付成功通知,必须回写以"success"(无关大小写)开头的字符串,即使您收到成功通知时发现该订单已经处理过,也要正确回写"success",否则易宝支付将认为您的系统没有收到通知,启动重发机制,直到收到"success"为止。


13


?hmac


?签名数据


??


?Max(32)


产生hmac需要两个参数,并调用相关API.
参数1: STR,列表中的参数值按照签名顺序拼接所产生的字符串,注意null要转换为 "",并确保无乱码.
参数2: 商户密钥.见"如何获得商户密钥"
各语言范例已经提供封装好了的方法用于生成此参数。
如果以上两个参数有错误,则该参数必然错误,见"抱歉,交易签名无效."

?

这些参数需要追加到URL后面。

但是要注意,这些参数的值需要加密。加密的密钥和加密算法易宝都会提供!

?

其中p8_Url表示当支付成功后,返回到电商的哪个页面。这说明我们需要写一个显示结果的页面。第三方在支付成功后,会重定向到我们指定的返回页面,而且还会带给我们一些参数,我们的页面需要获取这些参数,显示在页面中。下面是第三方返回的参数:


订 单 查 询 返 回 参 数


参数名称


参数含义


参数长度


参数说明


签名顺序


r0_Cmd


业务类型


Max(20)


订单查询请求,固定值
"QueryOrdDetail"


1


r1_Code


查询结果

?
为"1": 查询正常;
为"50": 订单不存在.


2


r2_TrxId


易宝支付交易流水号


Max(50)

?
3


r3_Amt


支付金额


Max(20)


单位:元,精确到分.


4


r4_Cur


交易币种


Max(10)


固定值 "RMB".


5


r5_Pid


商品名称


Max(20)


易宝支付返回商户设置的商品名称.
此参数如用到中文,请注意转码.


6


r6_Order


商户订单号


Max(50)


易宝支付返回商户订单号.


7


r8_MP


商户扩展信息


Max(1000)


商户可以任意填写1K的字符串,支付成功时将原样返回.
此参数如用到中文,请注意转码.


8


rb_PayStatus


支付状态

?
"INIT" 未支付;
"CANCELED" 已取消;
"SUCCESS" 已支付.


9


rc_RefundCount


已退款次数

? ?
10


rd_RefundAmt


已退款金额

? ?
11


?hmac


?签名数据


Max(32)


产生hmac需要两个参数,并调用相关API.
参数1: STR,列表中的参数值按照签名顺序拼接所产生的字符串,注意null要转换为 "".
参数2: 商户密钥.见"如何获得商户密钥"
各语言范例已经提供封装好了的方法用于生成此参数。

?

?

4 开发第三方在线支付系统

步骤:

  • index.jsp页面:一个表单,提交到BuyServlet,表单项有:订单编号、付款金额、选择银行;
  • BuyServlet:获取表单数据,准备连接第三方网关。因为在index.jsp页面中只给出3个参数,而第三方需要的参数有N多,页面没有给出的参数由BuyServlet补充。而且参数还需要加密,这也需要在BuyServlet中完成;
  • BackServlet:当用户支付成功后,第三方会重定向到我们指定的返回页面,我们使用BackServlet作为返回页面,它用来接收第三方传递的参数,显示在页面中。

?

因为已经有了在易宝的注册商号,所以我们就不用自己去注册商号了。所以这里使用易宝做为第三方支付平台来测试。因为我本人没有电商(必须通过ICP认证的电商),所以也不能在第三方注册商号。

我们现在使用的易宝商号是由传智播客提供的,巴巴运动网在易宝注册的商号。所以在测试时支付的钱都给了巴巴运动网在易宝注册的商号了。

?

第一步:index.jsp


<form
action=""
method="post">

????订单号:<input
type="text"
name="p2_Order"/><br/>

????金 额:<input
type="text"
name="p3_Amt"/><br/>

????选择银行:<br/>

????<input
type="radio"
name="pd_FrpId"
value="ICBC-NET-B2C"/>工商银行

????<img
src="bank_img/icbc.bmp"
align="middle"/>

????<input
type="radio"
name="pd_FrpId"
value="BOC-NET-B2C"/>中国银行

????<img
src="bank_img/bc.bmp"
align="middle"/><br/><br/>

????<input
type="radio"
name="pd_FrpId"
value="ABC-NET-B2C"/>农业银行

????<img
src="bank_img/abc.bmp" align="middle"/>

????<input
type="radio"
name="pd_FrpId"
value="CCB-NET-B2C"/>建设银行

????<img
src="bank_img/ccb.bmp" align="middle"/><br/><br/>

????<input
type="radio"
name="pd_FrpId"
value="BOCO-NET-B2C"/>交通银行

????<img
src="bank_img/bcc.bmp" align="middle"/><br/>

????<input
type="submit"
value="确认支付"/>

</form>


?

每个银行对应的值:


可直连银行


pd_FrpId参数值


对应支付通道名称


LOGO图片


1000000-NET?


易宝会员支付


??


ICBC-NET-B2C ?


工商银行



CMBCHINA-NET-B2C ?


招商银行



ABC-NET-B2C ?


中国农业银行



CCB-NET-B2C ?


建设银行



BCCB-NET-B2C ?


北京银行



BOCO-NET-B2C ?


交通银行



CIB-NET-B2C ?


兴业银行



NJCB-NET-B2C ?


南京银行



CMBC-NET-B2C ?


中国民生银行



CEB-NET-B2C ?


光大银行



BOC-NET-B2C ?


中国银行



PINGANBANK-NET ?


平安银行



CBHB-NET-B2C ?


渤海银行



HKBEA-NET-B2C ?


东亚银行



NBCB-NET-B2C ?


宁波银行



ECITIC-NET-B2C ?


中信银行(需要证书才能连接到银行)



SDB-NET-B2C ?


深圳发展银行



GDB-NET-B2C ?


广东发展银行



SHB-NET-B2C ?


上海银行



SPDB-NET-B2C ?


上海浦东发展银行



POST-NET-B2C ?


中国邮政



BJRCB-NET-B2C ?


北京农村商业银行



HXB-NET-B2C?


华夏银行(此功能默认不开通,如需开通请与易宝支付销售人员联系)



CZ-NET-B2C ?


浙商银行


?

第二步:BuyServlet.java


public
class BuyServlet extends HttpServlet {

????public
void doPost(HttpServletRequest request, HttpServletResponse response)

????????????throws ServletException, IOException {

????????request.setCharacterEncoding("utf-8");

????????response.setContentType("text/html;charset=utf-8");

?

????????String p0_Cmd = "Buy";// 业务类型,固定值为buy,即"买"

????????String p1_MerId = "10001126856";// 在易宝注册的商号

????????String p2_Order = request.getParameter("p2_Order");// 订单编号

????????String p3_Amt = request.getParameter("p3_Amt");// 支付的金额

????????String p4_Cur = "CNY";// 交易种币,固定值为CNY,表示人民币

????????String p5_Pid = "";// 商品名称

????????String p6_Pcat = "";// 商品各类

????????String p7_Pdesc = "";// 商品描述

????????String p8_Url = "http://localhost:8080/buy/BackServlet";// 电商的返回页面,当支付成功后,易宝会重定向到这个页面

????????String p9_SAF = "";// 送货地址

????????String pa_MP = "";// 商品扩展信息

????????String pd_FrpId = request.getParameter("pd_FrpId");// 支付通道,即选择银行

????????String pr_NeedResponse = "1";// 应答机制,固定值为1

?

????????// 密钥,由易宝提供,只有商户和易宝知道这个密钥。

????????String keyValue = "69cl522AV6q613Ii4W6u8K6XuW8vM1N6bFgyv769220IuYe9u37N4y7rI4Pl";

?

????????// 通过上面的参数、密钥、加密算法,生成hmac值

????????// 参数的顺序是必须的,如果没有值也不能给出null,而应该给出空字符串。

????????String hmac = PaymentUtil.buildHmac(p0_Cmd, p1_MerId, p2_Order, p3_Amt,

????????????????p4_Cur, p5_Pid, p6_Pcat, p7_Pdesc, p8_Url, p9_SAF, pa_MP,

????????????????pd_FrpId, pr_NeedResponse, keyValue);

????????

????????// 把所有参数连接到网关地址后面

????????String url = "https://www.yeepay.com/app-merchant-proxy/node";

????????url += "?p0_Cmd=" + p0_Cmd +

????????????????"&p1_MerId=" + p1_MerId +

????????????????"&p2_Order=" + p2_Order +

????????????????"&p3_Amt=" + p3_Amt +

????????????????"&p4_Cur=" + p4_Cur +

????????????????"&p5_Pid=" + p5_Pid +

????????????????"&p6_Pcat=" + p6_Pcat +

????????????????"&p7_Pdesc=" + p7_Pdesc +

????????????????"&p8_Url=" + p8_Url +

????????????????"&p9_SAF=" + p9_SAF +

????????????????"&pa_MP=" + pa_MP +

????????????????"&pd_FrpId=" + pd_FrpId +

????????????????"&pr_NeedResponse=" + pr_NeedResponse +

????????????????"&hmac=" + hmac;

????????System.out.println(url);

????????// 重定向到网关

????????response.sendRedirect(url);

????}

}

?

第三步:BackServlet


public
class BackServlet extends HttpServlet {

????public
void doGet(HttpServletRequest request, HttpServletResponse response)

????????????throws ServletException, IOException {

????????response.setContentType("text/html;charset=utf-8");

????????/*

???????? * 易宝会提供一系列的结果参数,我们获取其中需要的即可

???????? * 获取支付结果:r1_Code,1表示支付成功。

???????? * 获取支付金额:r3_Amt

???????? * 获取电商的订单号:r6_Order

???????? * 获取结果返回类型:r9_BType,1表示重定向返回,2表示点对点返回,

???????? * 但点对点我们收不到,因为我们的ip都是局域网ip。

???????? */

????????String r1_Code = request.getParameter("r1_Code");

????????String r3_Amt = request.getParameter("r3_Amt");

????????String r6_Order = request.getParameter("r6_Order");

????????String r9_BType = request.getParameter("r9_BType");

????????

????????if(r1_Code.equals("1")) {

????????????if(r9_BType.equals("1")) {

????????????????response.getWriter().print("<h1>支付成功!</h1>");//其实支付不成功时根本易宝根本就不会返回到本Servlet

????????????????response.getWriter().print("支付金额为:" + r3_Amt + "<br/>");

????????????????response.getWriter().print("订单号为:" + r6_Order + "<br/>");

????????????}

????????}

????}

}

时间: 2024-08-04 03:35:50

Day24-26 项目练习(图书商城)的相关文章

web day24 小项目练习图书商城, 用户,模块(注册,激活,登陆,退出),分类/图书模块

图书商城 模块 用户模块 分类模块 图书模块 购物车模块 订单模块 功能分析 前台 用户模块:注册/激活/登陆/退出 分类模块:查看所有分类 图书模块:查询所有图书/按分类查询图书/查询图书详细(id) 购物车模块:添加/清空/删除购物车条目 /我的购物车(按用户查询) 订单模块:生成订单/我的订单(按用户查询)/按id查询订单/确认收货/ /付款功能(只跳转到银行页面)/付款回调功能 后台 管理员:登陆 分类管理:增/删/改/查 图书管理(我的):增(上传图片)/删/改/查 订单模块:查询所有

web day25 web day24 小项目练习图书商城, 购物车模块,订单模块,支付(易宝支付)

购物车模块 购物车存储: 保存在session中(本次使用的) 保存在cookie中 保存在数据库中 购物车相关类 购物车结构 CartItem:包含图书和数量,小计 Cart:包含一个Map<String,CartItem>和部分购物车操作方法 修改登录方法,在用户登录成功后,马上在session中添加一辆车 页面负责遍历存在session域中的购物车属性 添加购物车条目 清空购物车条目 指定删除购物车条目 图 我的购物车 top.jsp中存在一个链接:我的购物车 我的购物车直接访问/jsp

web day26 小项目练习图书商城 后台分类管理模块,图书管理模块,前台登陆过滤

后台 后台的内容,必须要设置权限 用户可以访问一个网站的哪些内容? dao:不行 / service:不行 servlet:能 / jsp:能 用户可以访问的只有WEB层 分类管理 功能:增删改查 相关类 其他不变,为管理员提供单独的Servlet,然后给这个Servlet添加过滤器! web.servlet.admin:AdminCategoryServlet 查看所有分类 (略)同前台 只是转发到不同的页面 添加分类 add.jsp→AdminCatetgoryServlet#add() 1

JavaWeb网上图书商城完整项目--day02-4.regist页面提交表单时对所有输入框进行校验

1.现在我们要将table表中的输入的参数全部提交到后台进行校验,我们提交我们是按照表单的形式提交,所以我们首先需要在table表外面添加一个表单 <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core&

基于SSH的网上图书商城-JavaWeb项目-有源码

开发工具:Myeclipse/Eclipse + MySQL + Tomcat 项目简介: 技术:Java:JSP:JDBC,struts2,spring,hibernate数据库: mysqlweb服务器:tomcat集成开发工具: My Eclipse2014基于SSH的网上图书商城系统主要实现以下功能.本系统结构如下:1,游客访问 |--书店首页 查看精品推荐,最新出版的图片信息列表 |--书店简介 |--精品推荐 |--最新出版 |--优惠促销 2,会员访问 |--用户登陆,实现用户的登

Javaweb实现的优优图书商城(开放源码)

原文地址:http://www.cnblogs.com/liaoyu 源码地址:https://github.com/liaoyu/uushop 贴出一个大学时做的小项目,供有需要的朋友参考,名为优优图书商城,下面为关于它的一些介绍 主要功能介绍: 用户注册.登录.个人信息管理.通过邮件找回密码 图书搜索.购买.在线浏览,购物车管理 后台echart图表显示.源代码在线编辑 主要技术: 数据库 : mysql 后台语言: Java 后台框架: Hibernate Spring JPA Compa

简陋的图书商城应用(无结算页面)

WEB应用总览 1.建立好相应的包,从底层开始开发 domain包添加Book类 package cn.itcast.domain; public class Book { private String id; private String name; private String author; private Double price; private String description; public Book() { super(); // TODO Auto-generated co

MVC模式开发图书商城项目分析

MVC模式开发图书商城项目分析 1. 功能分析 1.用户注册 2.用户登录 3.添加商品(CURD) 4.商品查看-- 列表查询 5.商品详情页面 6.将商品添加购物车 7.查看购物车 8.修改购物车 9.生成订单 10.订单查看(取消) 11.在线支付 12.下载销售榜单 游客(未登录): 注册.登陆.商品查看 商城注册用户 : 商品查看.添加商品到购物车.购物车管理.生成订单.订单管理.在线支付 管理员 : 添加商品.商品管理.查看订单 .榜单查看(导出) 2. 系统设计 1技术选型 (系统

Javaweb实现的优优图书商城(含源码)

原文地址:http://www.cnblogs.com/liaoyu/p/uushop.html 源码地址:https://github.com/liaoyu/uushop 贴出一个大学时做的小项目,供有需要的朋友参考,名为优优图书商城,下面为关于它的一些介绍 主要功能介绍: 用户注册.登录.个人信息管理.通过邮件找回密码 图书搜索.购买.在线浏览,购物车管理 后台echart图表显示.源代码在线编辑 主要技术: 数据库 : mysql 后台语言: Java 后台框架: Hibernate Sp