本次任务要求:结合之前的数据可视化,数据爬取,配合服务器实现外网访问,并做出一个手机app实现访问数据。!!!【由于写该博客时插入图片出现问题,因此效果无法展示,部分地方会进行文字描述】
思路分析:数据可视化和数据爬取沿用前两周任务代码即可,问题在于服务器搭建和app的制作。服务器我在阿里云以学生价租用了一个, app使用AndroID Studio制作即可,需要解决的问题是AndroID访问远程MysqL数据库。
关于使用服务器实现外网访问Web项目:要实现外网访问Web项目,需要在服务器上搭建jdk和Tomcat,将本机上相应Web项目打包成war文件后,复制到远程服务器上Tomcat中webapps文件夹下。随后要在服务器上配置信息:找到服务器实例的安全组,在配置规则里加入端口8080/8080的自定义TCP,入方向和出方向我都设置了一次。在一切配置完之后,即可通过【http://+你的公网ip地址+/项目名/项目名下xx.HTML或xx.Jsp】格式外网访问你的项目。
要实现实时更新数据信息,数据爬取入库和读取MysqL数据库 *** 作需要在远程服务器上实现,因此要在远程服务器上下载MysqL和Python相关应用,我使用的是Navicat for MysqL配合MysqL数据库进行使用。在配置时会出现连接数据库失败的情况,解决方法如下:在服务器实例安全组的配置规则中加入端口3306/3306(Navicat 里可以从连接属性上看端口)的自定义TCP。设置后数据库连接成功。python爬取 *** 作没有变化。使用java实现读取数据并将其可视化 *** 作也没有变化,由于你将其打包成war文件并复制进远程桌面的Tomcat的webapps文件夹下,它所访问的数据库不是本地数据库,而是远程服务器下的数据库。
app搭建:这里是重头戏,一般的搜索,跳转页面之类的不用再说,问题在于app访问远程服务器的MysqL数据库,从而拿到数据显示。一开始我在思考怎么能连接上数据库,以前写的记账本连接的是sqlite数据库,是不一样的。后来查阅发现可以使用httpURLConnection访问java文件的Servlet,从中拿到数据即可(因为实现可视化需要在后台遍历查询之后通过Servlet将值传到前端),代码如下:
1 package com.example.yiqing; 2 3 import androIDx.appcompat.app.AppCompatActivity; 4 5 import androID.content.Intent; 6 import androID.os.Bundle; 7 import androID.os.Handler; 8 import androID.os.Message; 9 import androID.text.method.ScrollingMovementMethod; 10 import androID.vIEw.VIEw; 11 import androID.Widget.button; 12 import androID.Widget.TextVIEw; 13 14 import org.Json.JsONArray; 15 import org.Json.JsONObject; 16 17 import java.io.BufferedReader; 18 import java.io.DataOutputStream; 19 import java.io.IOException; 20 import java.io.inputStreamReader; 21 import java.io.OutputStream; 22 import java.net.httpURLConnection; 23 import java.net.URL; 24 import java.net.URLEncoder; 25 26 public class Watch extends AppCompatActivity { 27 private TextVIEw show; 28 private button see; 29 30 //利用Handler实现更改页面 31 private Handler handler=new Handler(){ 32 public voID handleMessage(androID.os.Message msg){ 33 Bundle bundle=new Bundle(); 34 bundle=msg.getData(); 35 String ans=bundle.getString("result"); 36 if(ans!=null){ 37 show.setText(ans); 38 } 39 } 40 }; 41 @OverrIDe 42 protected voID onCreate(Bundle savedInstanceState) { 43 super.onCreate(savedInstanceState); 44 setContentVIEw(R.layout.activity_watch); 45 show=(TextVIEw)findVIEwByID(R.ID.show); 46 show.setMovementMethod(ScrollingMovementMethod.getInstance()); 47 see=(button)findVIEwByID(R.ID.see); 48 49 see.setonClickListener(new VIEw.OnClickListener(){ 50 @OverrIDe 51 public voID onClick(VIEw vIEw){ 52 //写下要访问的servlet路径 53 final String path="http://47.98.228.220:8080/PaQu/ChartServlet"; 54 //使用httpURLConnection需要子线程 55 new Thread(new Runnable() { 56 @OverrIDe 57 public voID run() { 58 Intent intentdata=getIntent(); 59 //从上一个页面拿到输入的日期数据 60 String date=intentdata.getStringExtra("date"); 61 String msg=""; 62 httpURLConnection conn=null; 63 try{ 64 URL url=new URL(path); 65 conn=(httpURLConnection)url.openConnection(); 66 //设置post格式,这里格式要跟servlet里一致 67 conn.setRequestMethod("POST"); 68 //设置超时时间 69 conn.setConnectTimeout(5000); 70 conn.setReadTimeout(5000); 71 //post格式不能用缓存 72 conn.setUseCaches(false); 73 conn.setDoinput(true); 74 String data="date="+date; 75 //将传给servlet的数据写入传输 76 OutputStream out=conn.getoutputStream(); 77 //这里注意要更改传输数据的格式,getBytes() 78 out.write(data.getBytes()); 79 out.flush(); 80 out.close(); 81 conn.connect(); 82 83 //这里开始接收从servlet里传回来的数据 84 BufferedReader reader=new BufferedReader(new inputStreamReader(conn.getinputStream())); 85 String line=null; 86 //传回来的是一个JsONArray类型的数据,需要对其进行解析 87 if((line=reader.readline())!=null){ 88 //开始解析 89 JsONArray JsonArray=new JsONArray(line); 90 for(int i=0;i<JsonArray.length();i++){ 91 JsONObject JsonObject=JsonArray.getJsONObject(i); 92 String province=JsonObject.getString("Province"); 93 String confirmed=JsonObject.getString("Confirmed"); 94 String cured=JsonObject.getString("Cured"); 95 String dead=JsonObject.getString("Dead"); 96 msg=msg+"省份:"+province+" 确诊:"+confirmed+" 治愈:"+cured+" 死亡:"+dead+"\n"; 97 } 98 } 99 //将信息使用bundle封装,传给handler100 Bundle bundle=new Bundle();101 bundle.putString("result",msg);102 Message msg1=new Message();103 msg1.setData(bundle);104 handler.sendMessage(msg1);105 conn.disconnect();106 }catch(Exception e){107 e.printstacktrace();108 }109 }110 }).start();111 }112 });113 }114 115 }
使用httpURLConnection需要用到线程,需要注意servlet路径,还有接收servlet传回来的信息时,由于我这里是Json数据,需要进行解析。子线程中为了能够进行页面更改,使用handler实现 *** 作。
最后给出psp表格:
PSP2.1 | Personal Software Process Stages | Time/Real time |
Planning | 计划 |
|
·Estimate | ·估计这个任务需要多长时间 | 2天/1天 |
Development | 开发 |
|
·Analysis | ·需求分析(包括学习新技术) | 1天/7-8小时 |
·Design Spec | ·生成设计文档 | 0/0 |
·Design RevIEw | ·设计复审(和同事审核设计文档) | 0/0 |
·Coding Standard | ·代码规范(为目前的开发制定合适的规范) | 0/0 |
·Design | ·具体设计 | 12小时/6小时 |
·Coding | ·具体编码 | 12小时/12小时 |
·Code RevIEw | ·代码复审 | 0/0 |
·Test | ·测试(自我测试,修改代码,提交修改) | 3-6小时/3-6小时 |
Reporting | 报告 |
|
·Test Report | ·测试报告 | 1小时/1小时 |
·Size Measurement | ·计算工作量 | 30分钟/30分钟 |
·Postmortem&Process Improvement Plan | ·事后总结,并提出过程改进计划 | 20分钟/20分钟 |
| 合计 | 2天/1天 |
总结
以上是内存溢出为你收集整理的利用服务器实现疫情查询小系统(Web版+APP)全部内容,希望文章能够帮你解决利用服务器实现疫情查询小系统(Web版+APP)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)