电子商务大作业
作业要求
制作一个简单的电子商务网站具有以下功能
1 能进行用户注册、登录。用户信息保存在数据库中。
2能对商品信息进行维护增加、删除、修改。商品信息保存在数据库中。
3实现简单的购物车功能能对所选择的商品进行列表显示并对价格进行统计。
纸质报告要求
1 实现过程说明
2数据库设计说明
3运行效果
4主要源代码
- 、创建用户注册、登录。用户信息保存在数据库中
1创建数据库表
在MyS QL中创建一个名为homeworks的数据库并在该数据库中创建一张名为User的表格。字段名数据类型是否主键
2)安装所需的第三方软件包
在testapp/WEB-INF新建lib目录并将以下需要的第三方软件包拷贝到lib目录卜:j stl.j ar>standard.j ar>mysql-connector-j ava-5.0.7-b in.j aro
3)配置JDBC数据源wcb.xml页面类容如下
<?xn) l vcrsion=/ l. 0 z encoding=//ISO-8859-1/z?>
<web-app xmlns= http://java ・ sun. com/xml/ns/javaee zxmlns:xsi二〃http://www. w3. org/2001/XMLSchcma-instancc/zxsi : schemaLocation= http: //java ・ sun. com/xml/ns/javaeehttp://java ・ sun ・ com/xml/ns/javaoc/wob一app 2 5.xsd〃 version二"2. 5">
<!一一Used by the JSTL database actions -->
<context-param>
<param-name>javax ・ servlet ・ jsp ・ jstl ・ sql. dataSource </param-name>
<param-valuc>jdbc:mysql://localhost:3306/homoworks?uscr二root&password=root, com. mysq1. jdbc ・ D river</param-value>
</contcxt-param>
<description>
Servlet and JSP Examples.
</description>
<display-name>Servlet and JSP Examples</display-name>
<servlet>
<servlet-name>Test</servlet-name>
<display-name>Test</display-name>
<description>A test Servlet</description>
<servlet-class>test ・ ServletTest </servlet-class>
</servlet>
<servlet-mapping>
〈servlet - n?ime>Tes t〈 /servlet-name〉
<url-pattern>/Test</url-pattern>
</servlet-mapping>
</web-app>
4)建立和信息录入相关的JSP页面
Index.jsp网站首页
<html>
<head>
<titlc>Scarch in User Databasc</titlc>
</head>
<body bgco 1 or=wh i t e/?>
Welcome to my website home page
<P>if you are a member please click login
<P>if not then click on the registration
<P>
<br/>
<a hrcf= /register. jsp">
<input type 二"button" value=/zregi strati on" />
</a>
<a href=//login. jsp">
<input typo二"button" valuc= login" />
</a>
</body>
</html>register.jsp:用于注册用户信息的录入。
<%@ page contentType二"text/html"%>
<%@ taglib prefix二"c" uri=z http://java. sun. com/jsp/jstl/core"%><%@ tagl ib prefix二"fn" uri= zhttp://java. sun. com/jsp/jstl/functions"%><html>
<head>
<title>User Entry Form</title>
</head>
<body>
Registered User Interface
<P>
Please enter information about a user below:
<form action=//validate. jsp" method二"post"〉
<table>
<tr>
<td>Login Name:</td>
<td><input type二"text" name= z 1 oginNamevalue=z/$ {fn: escapeXml (param, logi nName) }">
</td>
<td>${fn:escapeXml (loginNameError) }</td></tr>
<tr>
<td>Password:</td>
<td><input type二"text" name=z passwordz value=//$ (fn: escapeXml (param, password) }"></td><td>${fn:escapeXml (passwordError) }</td>
</tr>
<tr>
<td>First Name:</td>
<td><input type="text" name=//firstNamez value二"$ {fn:escapeXml (param, firstName) }"></td><td>${fn:escapeXml (f irstNameError) }</td>
</tr>
<tr>
<td>Last Name:</td>
<td>〈in put type 二"text" n ame=z last Namez/value=z $ (fn: escapeXml (param, last Name) } z></td><td>${fn:escapeXml (lastNamcError) }</td>
</tr>
<tr>
<td>Emai1 Address:</td>
<td><input type二"text" namc二"emailAddress" value=/ $ {fn:escapeXml (param, cmailAddrcss) }"></td>
<td>${fn:escapeXml (cmailAddrcssError) }</td>
<td>(Use format name@company. com) 〈 /td>
</tr>
<tr>
<td colspan=2Xinput typc="submit" value二"Submit"></td>
</tr>
</table>
</form>
</body>
</html>val idate.jsp 用于验证录入的用户信息
程序代码如下
<%@ taglib prefix二"c" uri=/zhttp://java. sun. com/jsp/jstl/core/z%><%@ taglib prefix二"fmt"uri=//http://java. sun. com/jsp/jstl/fmt"%><c:set var二"isValid" value二"tme" />
<c: if test= ${empty param- loginName}zz>
<c: set varvalue二"Login missing" />
<c:set var= isValid / value二"false" />
</c: if>
<c: if test= $ {empty param. password} z>
<c:set var/>
<c:set var=z isValid z value二"faIse" />
</c: if>
<c: if test= ${empty param- firstName}zz>
<c:set var〃 />
<c:set var二"isValid" value二"false" />
</c: if>
<c: if test二〃 $ {empty param・ 1 astName} >
<c:set var二〃 />
<c:set var="isVaJicT value二"false" />
</c: if>
<c: if test=/ $ (empty param, emai 1 Address}
<c: set var= emai 1 AddressError z scope二"request" value=/zEmai 1 Address missing" /><c:set var二"isValid" value二"false" />
</c: if><c:choose>
<c:when test二"$ {isValid}">
<jsp:forward page二"store, jsp" />
</c:whon>
<c:otherwisc>
<jsp:forward page二"register ・ jsp" />
〈 /c:otherwise〉
</c:choose>store.jsp用于将录入的信息保存到数据库中。
程序代码如下
<%@ taglib prefix=〃c〃 uri二〃http://java ・ sun. com/jsp/jstl/core〃 %>
<%@taglib prefix=*sql/ uri二"http://java. sun. com/jsp/jstl/sql"%><%@taglib prefix二"fmt"uri=zhttp://java. sun. com/jsp/jstl/fmt/z%><%—
See if the user is already defined. If not, insert theinfo, else update it.
—%>
<sql: query var= /user >
SELECT * FROM User
WHERE LoginName = ?
<sql:param value二〃 $ {param, loginName}" /></sql:query>
〈--
Deal with the date values: parse the register date and create a Date object from it, and createa new variable to hold the current date. - -〉
<fmt :parseDate value=/z$ {param. registerDate) z var=/ parsedRegisterDate/z pattern二〃yyyy_MM-dd〃/>
<jsp:useBean id二"now" class二〃jnva. util. Date" />
<c:choose>
<c:when test二〃 ${user- rowCount == 0}">
<sql:update>
INSERT INTO User
(LoginName, Password, FirstName, LastNamc, EmailAddress)
VALUES
(?, ?, ?, ?, value二〃 $ {param・ loginName}" />
?) value==
<sql:param z$ {param. firstName}" /> value二〃
<sql:param $ {param. lastN且me} 〃 />value.
<sql:param emailAddress} z />
<sql:param
<sql:param </sql:update>
</c:when>
<c:otherwise>
<sql:update>
UPDATE User
SET Password = ?,
FirstName = ?,
LastNamc = ?,
EmailAddress = ?,
WHERE
LoginName 二? valuc=
<sql:param 二〃 $ {param. firstName}" />
<sql:param valuc=/>
<sql:param value= $ {param. emailAddress}z />
<sql:param value= z$ {param. loginName} z />
<sql:param
</sql:update>
</c:otherwise>
</c:choose>
<%―Get the new or updated data from the database --%><sql:query var= newUser!nfo z scope二〃session〉
SELECT * FROM User
WHERE LoginName 二?
<sql: param value=/ $ {param. loginName}/>
</sql:query>
<%-一Redirect to the confirmation page --%><c:redirect url= confirmation. jspz />confirmationjsp:用于显示己保存到数据的信息。程序代码如下
<%@ page contentType二"text/html"%>
<%@ taglib prefix二"c" uri=z http://java. sun. com/jsp/jstl/core"%>
<%@ taglib prefix二"fn" uri=z http://java. sun. com/jsp/jstl/functions"%><html>
<head>
<title>User Info Stored</title>
</head>
<body bgcolor= /whitez >
<form action二"login, jsp" method二"get">
This is the information stored in the homeworks database:
<table>
<c: forEach i tcms=/z$ {newUserlnfo. rows} " var= row z>
<c:forEach items二"$ {row} 〃 var二"column"〉
<tr>
<td align二right>
<b>${fn:escapcXml (column, key) } :</b>
</td>
<td>
${fn:escapeXml (column, value) }
</td>
</tr>
</c:forEach>
</c:forEach〉
<td><input type二"submit" value二"GoBack">〈 /td>
</table>
</body>
</html>
二.用户登陆lo gin.j sp注册用户登陆界面
<%@page contentType=, ,text/htmr,%>
<%@taglib prcfix=HcM uri=,,http://java.sun.com/jsp/jstl/coren%>
<%@taglib prefix二"fn”uri="http://java.sun.com/jsp/jstl/functions"%>
<h tm l>
<head>
<title>Search in User Database</title>
</head>
<body bgcolor=HwhitcH>
<tab le>
<tr>
<td>login Name:</td>
<td><input type=</td>
</tr>
2021年恒创科技618活动香港美国服务器/云服务器/高防全场3折抢购,老客户续费送时长,每日限量秒杀。云服务器每款限量抢购,香港美国独服/高防每款限量5台/天,香港节点是CN2线路还不错。福利一:爆品秒杀 超低价秒杀,秒完即止;福利二:云服务器 火爆机型 3折疯抢;福利三:物理服务器 爆款直降 800元/月起;福利四:DDOS防护 超强防御仅 1750元/月。点击进入:2021年恒创科技618活...
创梦网络怎么样,创梦网络公司位于四川省达州市,属于四川本地企业,资质齐全,IDC/ISP均有,从创梦网络这边租的服务器均可以****,属于一手资源,高防机柜、大带宽、高防IP业务,另外创梦网络近期还会上线四川眉山联通、广东优化线路高防机柜,CN2专线相关业务。广东电信大带宽近期可以预约机柜了,成都优化线路,机柜租用、服务器云服务器租用,适合建站做游戏,不须要在套CDN,全国访问快,直连省骨干,大网...
介绍:御速云成立于2021年的国人商家,深圳市御速信息技术有限公司旗下品牌,为您提供安全可靠的弹性计算服务,随着业务需求的变化,您可以实时扩展或缩减计算资源,使用弹性云计算可以极大降低您的软硬件采购成本,简化IT运维工作。主要从事VPS、虚拟主机、CDN等云计算产品业务,适合建站、新手上车的值得选择,拥有华东江苏、华东山东等国内优质云产品;香港三网直连(电信CN2GIA联通移动CN2直连);美国高...