chart and pie

02月20日(星期三)

 

under stuts1.1 JSP

Display.jsp================================

<body>
This is my JSP page. <br>
<P ALIGN="CENTER">
<%String url=(String)session.getAttribute("url"); %><!--EL works too-->
<img src="<%=url %>" width=500 height=300 border=0 usemap="#map0">
</P>
</body>

Login.jsp================================

<body>
This a struts page. <br>
<html:form action="/chart.do">
<html:submit/>
</html:form>


</body>

struts-config.xml Configuration===================

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.1//EN" "http://jakarta.apache.org/struts/dtds/struts-config_1_1.dtd">

<struts-config>
<data-sources >
<data-source key="mssql2000">
<set-property property="password" value="" />
<set-property property="minCount" value="1" />
<set-property property="maxCount" value="4" />
<set-property property="user" value="sa" />
<set-property property="driverClass" value="com.microsoft.jdbc.sqlserver.SQLServerDriver" />
<set-property property="description" value="" />
<set-property property="url" value="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs" />
<set-property property="readOnly" value="false" />
<set-property property="autoCommit" value="true" />
<set-property property="loginTimeout" value="" />
</data-source>

</data-sources>

<form-beans >
<form-bean name="pieForm" type="com.struts.form.PieForm" />

</form-beans>

<global-exceptions />
<global-forwards />
<action-mappings >
<action
attribute="pieForm"
input="/login.jsp"
name="pieForm"
path="/chart"
scope="request"
type="com.struts.action.ChartAction"
validate="false">
<forward
name="ok"
path="/Display.jsp"
contextRelative="true" />
</action>

</action-mappings>

<message-resources parameter="com.struts.ApplicationResources" />
</struts-config>

Web.xml Configuration========================

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<servlet>
<servlet-name>action</servlet-name>
<servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
<init-param>
<param-name>config</param-name>
<param-value>/WEB-INF/struts-config.xml</param-value>
</init-param>
<init-param>
<param-name>debug</param-name>
<param-value>3</param-value>
</init-param>
<init-param>
<param-name>detail</param-name>
<param-value>3</param-value>
</init-param>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet>
<servlet-name>DisplayChart</servlet-name>
<servlet-class>org.jfree.chart.servlet.DisplayChart</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DisplayChart</servlet-name>
<url-pattern>/servlet/DisplayChart</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>action</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
</web-app>

Src----------------------------------

formbean=======================

/*
* Generated by MyEclipse Struts
* Template path: templates/java/JavaClass.vtl
*/
package com.struts.form;

import javax.servlet.http.HttpServletRequest;
import org.apache.struts.action.ActionErrors;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionMapping;

/**
* MyEclipse Struts
* Creation date: 02-19-2004
*
* XDoclet definition:
* @struts.form name="pieForm"
*/
public class PieForm extends ActionForm {
/*
* Generated fields
*/

/** pienum property */
private String pienum;

/** piename property */
private String piename;

/** pieid property */
private String pieid;

/*
* Generated Methods
*/

/**
* Method validate
* @param mapping
* @param request
* @return ActionErrors
*/
public ActionErrors validate(ActionMapping mapping,
HttpServletRequest request) {
// TODO Auto-generated method stub
return null;
}

/**
* Method reset
* @param mapping
* @param request
*/
public void reset(ActionMapping mapping, HttpServletRequest request) {
// TODO Auto-generated method stub
}

/**
* Returns the pienum.
* @return String
*/
public String getPienum() {
return pienum;
}

/**
* Set the pienum.
* @param pienum The pienum to set
*/
public void setPienum(String pienum) {
this.pienum = pienum;
}

/**
* Returns the piename.
* @return String
*/
public String getPiename() {
return piename;
}

/**
* Set the piename.
* @param piename The piename to set
*/
public void setPiename(String piename) {
this.piename = piename;
}

/**
* Returns the pieid.
* @return String
*/
public String getPieid() {
return pieid;
}

/**
* Set the pieid.
* @param pieid The pieid to set
*/
public void setPieid(String pieid) {
this.pieid = pieid;
}
}

action-----------------------------

ChartAction====================

/*
* Generated by MyEclipse Struts
* Template path: templates/java/JavaClass.vtl
*/
package com.struts.action;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Vector;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.jfree.chart.ChartRenderingInfo;
import org.jfree.chart.ChartUtilities;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.entity.StandardEntityCollection;
import org.jfree.chart.labels.StandardPieToolTipGenerator;
import org.jfree.chart.plot.PiePlot3D;
import org.jfree.chart.servlet.ServletUtilities;
import org.jfree.data.general.DefaultPieDataset;

import com.business.ChartBusiness;
import com.struts.form.PieForm;

/**
* MyEclipse Struts
* Creation date: 02-19-2004
*
* XDoclet definition:
* @struts.action validate="true"
*/
public class ChartAction extends Action {
/*
* Generated Methods
*/

/**
* Method execute
* @param mapping
* @param form
* @param request
* @param response
* @return ActionForward
*/
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) {
// TODO Auto-generated method stub
ChartBusiness cb=new ChartBusiness();
Vector vc=cb.findAll();
DefaultPieDataset data = new DefaultPieDataset();
//数据初始化
// data.setValue("高中以下",380);
// data.setValue("高中",1620);
// data.setValue("大专",6100);
// data.setValue("本科",8310);
// data.setValue("硕士",3520);
// data.setValue("博士",180);
for(int i=0;i<vc.size();i++)
{
PieForm p=new PieForm();
p=(PieForm) vc.get(i);
data.setValue(p.getPiename(),Integer.parseInt(p.getPienum()));

}


//HttpSession session = request.getSession();

PiePlot3D plot = new PiePlot3D(data);//生成一个3D饼图
//plot.setURLGenerator(new StandardPieURLGenerator("DegreedView.jsp"));//设定图片链接
JFreeChart chart = new JFreeChart("",JFreeChart.DEFAULT_TITLE_FONT, plot, true);
chart.setBackgroundPaint(java.awt.Color.white);//可选,设置图片背景色
chart.setTitle("程序员学历情况调查表-By Alpha");//可选,设置图片标题
plot.setToolTipGenerator(new StandardPieToolTipGenerator());
StandardEntityCollection sec = new StandardEntityCollection();
ChartRenderingInfo info = new ChartRenderingInfo(sec);
PrintWriter w=null;
try {
PrintWriter out=response.getWriter();
w = new PrintWriter(out);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//500是图片长度,300是图片高度
//String filename = ServletUtilities.saveChartAsPNG(chart,500,300,info,session);
HttpSession session=request.getSession(true);
String filename="";
try {
filename = ServletUtilities.saveChartAsJPEG(chart,500,300,info,session);
ChartUtilities.writeImageMap(w,"map0",info,false);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

String graphURL = request.getContextPath() + "/servlet/DisplayChart?filename=" + filename;
session.setAttribute("url", graphURL);
return mapping.findForward("ok");
}
}

DBConnection=============================

package com.db;

import java.sql.*;
import java.util.*;

import javax.sql.*;

import org.apache.struts.action.ActionServlet;

public class DBConnection {

private static Connection con;

private static DBConnection dbcon = new DBConnection();

private DBConnection() {
}

public static DBConnection getDBConnection() {
return dbcon;
}

public static Connection geConnection() {

try {
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
} catch (ClassNotFoundException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}

try {
con = DriverManager
.getConnection(
"jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs",
"sa", "");
return con;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return con;
}
}

Dao================================

package com.dao;
import java.sql.*;
import java.util.Vector;

import com.db.*;
import com.struts.form.*;
public class ChartDao {
public Vector findAll()
{
Vector chartvc=new Vector();
String sql="select * from pie";
DBConnection dbcon=DBConnection.getDBConnection();
Connection con=dbcon.geConnection();
Statement st=null;
ResultSet rs=null;
try {
st=con.createStatement();
rs=st.executeQuery(sql);
if(rs!=null)
{
while(rs.next())
{
PieForm p=new PieForm();
p.setPieid(rs.getString(1));
p.setPiename(rs.getString(2));
p.setPienum(rs.getString(3));
chartvc.add(p);
}
}
return chartvc;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally
{
try {
rs.close();
st.close();
con.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

return chartvc;
}

}
Business==============================

package com.business;

import java.util.Vector;

import com.dao.ChartDao;

public class ChartBusiness {
public Vector findAll()
{
ChartDao cd=new ChartDao();
return cd.findAll();
}
}

 

sql =====================

create table pie

(

pieid int identity primary key,

piename varchar(20) not null,

pienum varchar(20)not null

)

OVER pie JPEG show up

《餐馆点餐管理系统——基于Java和MySQL的课程设计解析》 在信息技术日益发达的今天,餐饮行业的数字化管理已经成为一种趋势。本次课程设计的主题是“餐馆点餐管理系统”,它结合了编程语言Java和数据库管理系统MySQL,旨在帮助初学者理解如何构建一个实际的、具有基本功能的餐饮管理软件。下面,我们将深入探讨这个系统的实现细节及其所涉及的关键知识点。 我们要关注的是数据库设计。在“res_db.sql”文件中,我们可以看到数据库的结构,可能包括菜品表、订单表、顾客信息表等。在MySQL中,我们需要创建这些表格并定义相应的字段,如菜品ID、名称、价格、库存等。此外,还要设置主键、外键来保证数据的一致性和完整性。例如,菜品ID作为主键,确保每个菜品的唯一性;订单表中的顾客ID和菜品ID则作为外键,与顾客信息表和菜品表关联,形成数据间的联系。 接下来,我们来看Java部分。在这个系统中,Java主要负责前端界面的展示和后端逻辑的处理。使用Java Swing或JavaFX库可以创建用户友好的图形用户界面(GUI),让顾客能够方便地浏览菜单、下单。同时,Java还负责与MySQL数据库进行交互,通过JDBC(Java Database Connectivity)API实现数据的增删查改操作。在程序中,我们需要编写SQL语句,比如INSERT用于添加新的菜品信息,SELECT用于查询所有菜品,UPDATE用于更新菜品的价格,DELETE用于删除不再提供的菜品。 在系统设计中,我们还需要考虑一些关键功能的实现。例如,“新增菜品和价格”的功能,需要用户输入菜品信息,然后通过Java程序将这些信息存储到数据库中。在显示所有菜品的功能上,程序需要从数据库获取所有菜品数据,然后在界面上动态生成列表或者表格展示。同时,为了提高用户体验,可能还需要实现搜索和排序功能,允许用户根据菜品名称或价格进行筛选。 另外,安全性也是系统设计的重要一环。在连接数据库时,要避免SQL注入攻击,可以通过预编译的PreparedStatement对象来执行SQL命令。对于用户输入的数据,需要进行验证和过滤,防止非法字符和异常值。 这个“餐馆点餐管理系统”项目涵盖了Java编程、数据库设计与管理、用户界面设计等多个方面,是一个很好的学习实践平台。通过这个项目,初学者不仅可以提升编程技能,还能对数据库管理和软件工程有更深入的理解。在实际开发过程中,还会遇到调试、测试、优化等挑战,这些都是成长为专业开发者不可或缺的经验积累
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值