Unity同时充当移动端和后台的界面+Sevelet+Mysql+Tomcat 学生信息的录入
来源:互联网 发布:程序员证书怎么考 编辑:程序博客网 时间:2024/06/05 17:32
这个Demo中,Unity扮演两个角色:
unity做客户端界面,实现每个学生信息的录入
unity再做一个界面,实现读取所有学生信息并且展示出来
JavaWeb中的Servlet负责接收处理和响应Unity发过来的请求
Mysql用于存储所有学生的信息
服务器: tomcat
下面就看看具体的实现步骤:
Utniy中学生录入信息界面如下:
Unity这边三个脚本:
下面这张图是在Mysql中建立数据库和数据表的信息
经过上面的准备工作,下面先来看看客户端发数据,服务器接收数据并处理,最后将接收的数据保存到数据库 这条线
移动端代码如下,当点击提交按钮后,就会调用tijiao这个方法:
服务器端用于接收和处理客户端信息的Servlet,如下:
客户提交几条信息后,数据库中保存信息如下:
下面接着来看看,客户端向服务器请求所有的个人信息,并将信息展示出来这条线
先把客户端的滚动视图搭建起来:
这张图的锚点之所以靠上对齐,就是防止场景中item数量太少时,item居中显示,这样就不好看
还有一个问题,就是当所有item的高度总和超出显示框后,就涉及到一个如何保证首次显示滚动视图顶对齐的问题,解决办法如下:
建一个预设体,并且新建一个脚本item,然后将脚本赋值给预设体
挂在预设体身上的脚本:
服务器处理客户端请求的servlet:
客户端展示的信息如下截图:
下面这个工具类用于注册数据库的驱动,以及获取和释放连接,是实际使用时,可以直接拷贝复用
package com.shujuku.mysql;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;public class source { static String username; static String pwd; static String urlString; static { try { Class.forName("com.mysql.jdbc.Driver"); username = "root"; pwd = "root"; urlString = "jdbc:mysql://localhost:3306/person"; } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } //FR: 海涛高软(QQ技术交流群:386476712) public static Connection getConnection() throws Exception { //获取一个连接 Connection connection = DriverManager.getConnection(urlString, username, pwd); return connection; } public static void shifang(Connection con, PreparedStatement st, ResultSet rs) { //资源释放 if (rs != null) { try { rs.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { if (st != null) { try { st.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { if (con != null) { try { con.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } } } }}
下面这个工具类,主要负责数据库的操作(增删改查),在实际使用时,可以直接拷贝复用
package com.shujuku.mysql;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.util.ArrayList;import java.util.List;public class dbTools { public static void zeng(user u) throws Exception { //插 Connection con = source.getConnection(); String sql = "insert into biao01(name,shenGao,jiaXiang) values(?,?,?);"; PreparedStatement st = con.prepareStatement(sql); st.setString(1, u.getName()); st.setFloat(2, u.getShenGao()); st.setString(3, u.getJiaXiang()); st.executeUpdate(); source.shifang(con, st, null); } public static void shan(int dd) throws Exception{ // 删 Connection con = source.getConnection(); String sql = "delete from biao01 where id=?"; PreparedStatement st = con.prepareStatement(sql); st.setInt(1, dd); st.executeUpdate(); source.shifang(con, st, null); } public static void gai(user u) throws Exception{ // 改 Connection con = source.getConnection(); String sql = "update biao01 set shenGao=? where name=?"; PreparedStatement st = con.prepareStatement(sql); st.setFloat(1, Float.valueOf(u.getShenGao())); st.setString(2, u.getName()); st.executeUpdate(); source.shifang(con, st, null); } public static void cha() throws Exception{ // 查 Connection con = source.getConnection(); String sql = "select * from biao01 "; PreparedStatement st = con.prepareStatement(sql); ResultSet rs=st.executeQuery(); List< user> list=new ArrayList<user>(); while(rs.next()){ String name=rs.getString("name"); float shenGao=rs.getFloat("shenGao"); String jiaXiang=rs.getString("jiaXiang"); user uu=new user(name,shenGao,jiaXiang); list.add(uu); } source.shifang(con, st, rs); }}
服务器端用于封装一次请求信息的bean对象如下:
package com.shujuku.mysql;public class user { private int id;public int getId() { return id; } public void setId(int id) { this.id = id; }private String name;private float shenGao;private String jiaXiang;public String getName() { return name;}public void setName(String nameString) { this.name = nameString;}public float getShenGao() { return shenGao;}public void setShenGao(float shenGao) { this.shenGao = shenGao;}public String getJiaXiang() { return jiaXiang;}public void setJiaXiang(String jiaXiang) { this.jiaXiang = jiaXiang;}public user(String aa, float bb, String cc) { super(); this.name = aa; this.shenGao = bb; this.jiaXiang = cc;}public user() { super();}}
备注:
客户端读取json用的是 LitJson插件
服务器端输出json字符串用的是阿里云开发的 fastjson插件
FR:海涛高软(QQ技术群:386476712)
- Unity同时充当移动端和后台的界面+Sevelet+Mysql+Tomcat 学生信息的录入
- unity移动端+bootstrap后台界面+JavaWeb+Mysql+tomcat
- 学生信息的录入和打印,函数的封装
- java的那些事:实现学生信息录入和查看
- 简单的学生信息录入程序
- 学生的成绩录入
- 做学生信息录入删除查询修改系统的心得
- 实现学生信息录入的动态长度控制
- 实现学生信息录入的动态长度控制(链表)
- 基于学生信息录入排序分割实验的总结
- java小程序之学生信息录入界面
- 学生成绩的录入排列
- 录入学生信息
- 学生信息录入
- 多人同时录入信息时,获取刚添加的信息
- 关于录入界面的讨论
- 一个简单的Tk界面(可以录入和查询)
- 【学生信息管理系统】系统的界面与后台
- 程序员,如何写好文档?
- 文章标题
- 243. Shortest Word Distance
- Android开发学习—指纹识别系统的原理与使用
- 2016年工作笔记汇总
- Unity同时充当移动端和后台的界面+Sevelet+Mysql+Tomcat 学生信息的录入
- 没有需求,我们开发个毛?
- 中国剩余定理
- 上班两周-离职打算
- Macbook 下设置多ip
- unity移动端+bootstrap后台界面+JavaWeb+Mysql+tomcat
- @MappedSuperclass的用法
- windows、linux查看端口占用
- Ehcache 整合Spring 使用页面、对象缓存