第一阶段:Java语言基础
创新互联建站服务项目包括盐山网站建设、盐山网站制作、盐山网页制作以及盐山网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,盐山网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到盐山省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
★ Java语言基础
1、面向对象思维JAVASE
2、(类加载机制与反射,annotation,泛型,网络编程,多线程,IO,异常处理,常用API,面向对象,JAVA编程基础)
3、Java8新特性
JAVA战狼班第二阶段:数据库
★ 数据库
1、Oracle(SQL语句、SQL语句原理、SQL语句优化、表、视图
2、序列、索引、Oracle数据字典、Oracle 数据库PL/SQL开发
3、数据库设计原则、 MySQL 、 JDBC
第三阶段:Web基础
★ Web基础
1、HTML5(H5)基本文档结构、链接、列表、表格、表单;
2、CSS 基础语法、盒子模型、浮动布局、定位;
3、JavaScript语言基础、DOM 编程、事件模型等),JQuery,AJAX框架,XML,BootStrap组件
第四阶段:Java Web技术和主流框架
★ Java Web技术和主流框架
1、JSPServlet、struts2,hibernate4,spring4,JPA,maven
2、SpringData,SpringMVC,MyBatis,SpringSecurity,shiro,Nginx
第五阶段:Linux
★ Linux
1、Linux安装、熟悉Linux的基础命令、vi编辑器的使用、awk和sed命令使用、用户和组
2、文件及目录权限管理、使用ACL进行高级访问控制、网络配置和软件包安装、启动流程和服务管理
3、系统监控和日志管理、进程管理和计划任务、ssh远程登录、shell基础和shell脚本。
第六阶段:大数据技术(Hadoop和Spark)
★ 大数据技术(Hadoop和Spark)
1、Hadoop (Hadoop基础和环境搭建,HDFS体系结构,MapReduce;Hadoop的集群模式、HDFS联盟,利用ZooKeeper来实现Hadoop集群的HA(高可用性)功能
2、Yarn的任务调度机制,Apache Hive,Pig数据处理,集成Hadoop和Sqoop
3、Flume以及Apache Kafka来实现数据的交换,安装部署HBase,Storm)
4、Scala 语言(Scala环境搭建、Scala基础语法、模式匹配、重载与构造器、Map与reduce、元组、继承、StringContext,Option Some None,Tuple;集合方法和运算,future 对象同步处理和异步处理返回结果)
5、Spark(Spark搭建,Spark-shell 的使用,Spark-submit 提交应用, Spark的内核设计和实现,并对内核中的实现架构、运行原理进行详细的讲解;Spark生态体系中的各个组件,包括:Spark Core,Shark,Spark SQL和Spark Streaming等等)
第七阶段:项目
★ 项目
1、China-UCSP 项目 SSM(Spring+SpringMVC+MyBatis)
2、用户关系管理系统 S2SH+Maven+Nodejs+MySQL技术实战开发
3、电子商务交易平台 S2SH+Maven+Shiro+Oracle
加入定时任务,定期执行检查处理,发现库存不足,发送邮件/短信提示。
java后端的⼏种实现⽅式
java后端的⼏种实现⽅式
最近没事在做⼀些⼩题⽬,遇到需要提供http restful接⼝,通过接⼝操作zookeeper实现增删改查。虽然之前看过java后端的内容,但是基本忘的差不多了,这次梳理了⼀下,都是⼊门的东西。⾃⼰总结⽤,如有错误还请多指正。
⾸先说这次了解到的主要是三种⽅式:
第⼀种:servelet + jsp ⼿动配置项较多,⾮框架
第⼆种:Spring框架 ⽬前应该是后端主流实现⽅式吧
第三种:Spring boot 在Spring框架的基础上进⼀步简化了实现⽅式,通过⼏个注解就可以实现⾃动配置。
⼀、 servelet + jsp⽅式
开始的想法,由于只是简单的需求,所以没想引⼊Spring框架。这个应该是依赖最少的⽅式了。
以idea为例,说⼀下搭建过程:
参考:
⾸先项⽬应该是web项⽬,这个在创建的时候可以选择。如果⼀开始是maven项⽬,需要添加框架⽀持,添加完成后会⾃动⽣成web⽂件夹和web.xml配置⽂件。如图,在项⽬配置中添加就可以
添加完成后在artifacts选项卡中添加打包配置,点击后会出现模块选择,选中确定就可以了。
成功以后如下,点击ok关闭窗⼝就可以了,不需要其他配置。
然后开始编写servelet代码,继承HttpServlet类,重写doGet⽅法。只实现简单的打印⽂字到⽹页的功能,不需要编写jsp⽂件,只要servelet就可以实现。
@Override
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html; charset=utf-8");
response.setCharacterEncoding("UTF-8");
OutputStream out = response.getOutputStream();
out.write("hello".getBytes(StandardCharsets.UTF_8));
out.flush();
}
配置web.xml,按⾃⼰的servelet类名⾃⾏调整
servlet!--servlet类路径配置--
servlet-nameUtilsServlet/servlet-name
servlet-classcom.baidu.servlet.UtilsServlet/servlet-class /servlet
servlet-mapping!--servlet类映射配置--
servlet-nameUtilsServlet/servlet-name
url-pattern/UtilsServlet/url-pattern ##⽹页访问地址
/servlet-mapping
接下来配置tomcat应⽤:
配置好以后就可以运⾏了,浏览器地址输⼊访问地址,然后在后⾯加上/UtilsServlet (按项⽬调整,web.xml⾃⼰配置的servelet类访问路径),就可以看到 输出的⽂字了。当然这⾥可以再doGet⽅法⾥实现各种逻辑,返回jsp页⾯ ,返回json结果等,⼀般项⽬是再加上⼀个service层(package),将复杂的业务逻辑放在service中。
⼆、Spring框架(未实现,只是简单试了下搭建)
在之前的基础上添加Spring的框架⽀持。
两种⽅式:
1、还是在项⽬配置中添加
2、右键project – add framework support,这⾥虽然可以选择单个的⽀持,但是好像选了Spring MVC后就会⾃动包含所有组件(只选择Spring MVC,下次再添加spring的框架⽀持时,发现已经找不到了,说明应该默认所有都已添加),右边选择依赖位置,如果没有下载好的jar包,可以选择download,会在项⽬下⽣成lib⽂件夹,然后下载需要的jar包。也可以在maven添加依赖,这样就可以做到⽅便管理了。
三、Spring boot
最简单的⽅式。不⽤添加任何框架⽀持,对,Spring的也不需要,直接在pom⽂件中加上依赖就⾏,真⾹。
!-- 相关jar包 --
dependencies
!-- Springboot核⼼jar包 --
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter/artifactId
/dependency
!-- web开发包:包含Tomcat和Springmvc --
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-web/artifactId
/dependency
/dependencies
然后新建两个类,添加⼏个注解就可以打印出来hello world。
可以参考这篇博⽂
注意项⽬结构,app类要在controller的上层(否则报错:This application has no explicit mapping for /error, so you are seeing this as a fallback),同时需要新建⼀个package,不能将app类直接放在默认java⽂件夹下,不然代码会标红,原因是注解类型错误,当然可以改⽤其他注解来解决,我这⾥就不贴了。
¥
5.9
百度文库VIP限时优惠现在开通,立享6亿+VIP内容
立即获取
java后端的几种实现方式
java后端的⼏种实现⽅式
java后端的⼏种实现⽅式
最近没事在做⼀些⼩题⽬,遇到需要提供http restful接⼝,通过接⼝操作zookeeper实现增删改查。虽然之前看过java后端的内容,但是基本忘的差不多了,这次梳理了⼀下,都是⼊门的东西。⾃⼰总结⽤,如有错误还请多指正。
⾸先说这次了解到的主要是三种⽅式:
第⼀种:servelet + jsp ⼿动配置项较多,⾮框架
第 1 页
第⼆种:Spring框架 ⽬前应该是后端主流实现⽅式吧
第三种:Spring boot 在Spring框架的基础上进⼀步简化了实现⽅式,通过⼏个注解就可以实现⾃动配置。
⼀、 servelet + jsp⽅式
开始的想法,由于只是简单的需求,所以没想引⼊Spring框架。这个应该是依赖最少的⽅式了。
以idea为例,说⼀下搭建过程:
参考:
import java.util.*;
import java.awt.event.*;
import java.awt.*;
import javax.swing.*;
import java.io.*;
class 商品 extends Panel
{String 代号,名称;int 库存;float 单价;
商品(String 代号,String 名称,int 库存,float 单价)
{this.代号=代号;this.名称=名称;this.库存=库存;this.单价=单价;
}
}
class ShowWin extends JFrame implements ActionListener
{ Hashtable hashtable=null;
JTextField 代号文本框=new JTextField(),
名称文本框=new JTextField(),
库存文本框=new JTextField(),
单价文本框=new JTextField(),
查询文本框=new JTextField(),
查询信息文本框=new JTextField(),
删除文本框=new JTextField();
JButton b_add=new JButton("添加商品"),
b_del=new JButton("删除商品"),
b_xun=new JButton("查询商品"),
b_xiu=new JButton("修改商品"),
b_show=new JButton("显示商品清单");
JTextArea 显示区=new JTextArea(25,10);
ShowWin()
{super("仓库管理窗口");
hashtable=new Hashtable();
Container con=getContentPane();
JScrollPane pane=new JScrollPane(显示区);
显示区.setEditable(false);
JPanel save=new JPanel();
save.setLayout(new GridLayout(8,2));
save.add(new Label("输入代号:"));
save.add(代号文本框);
save.add(new Label("输入名称:"));
save.add(名称文本框);
save.add(new Label("输入库存:"));
save.add(库存文本框);
save.add(new Label("输入单价:"));
save.add(单价文本框);
save.add(new Label("单击添加:"));
save.add(b_add);
save.add(new Label("单击修改:"));
save.add(b_xiu);
save.add(new Label("输入查询代号:"));
save.add(查询文本框);
save.add(new Label("单击查询:"));
save.add(b_xun);
JPanel del=new JPanel();
del.setLayout(new GridLayout(2,2));
del.add(new Label("输入删除的代号:"));
del.add(删除文本框);
del.add(new Label("单击删除:"));
del.add(b_del);
JPanel show=new JPanel();
show.setLayout(new BorderLayout());
show.add(pane,BorderLayout.CENTER);
show.add(b_show,BorderLayout.SOUTH);
JSplitPane split_one,split_two;
split_one=new JSplitPane(JSplitPane.VERTICAL_SPLIT,save,del);
split_two=new
JSplitPane(JSplitPane.HORIZONTAL_SPLIT,true,split_one,show);
con.add(split_two,BorderLayout.CENTER);
JPanel xun=new JPanel();
xun.add(new Label("所得信息:"));
xun.add(查询信息文本框);
xun.setLayout(new GridLayout(2,1));
con.add(xun,BorderLayout.SOUTH);
b_add.addActionListener(this);
b_del.addActionListener(this);
b_xun.addActionListener(this);
b_xiu.addActionListener(this);
b_show.addActionListener(this);
}
public void actionPerformed(ActionEvent e)
{if(e.getSource()==b_add)
{String daihao=null,mingcheng=null;int kucun=0;float danjia=0.0f;
daihao=代号文本框.getText();mingcheng=名称文本框.getText();
kucun=Integer.parseInt(库存文本框.getText());
danjia=Float.valueOf(单价文本框.getText()).floatValue();
商品 goods=new 商品(daihao,mingcheng,kucun,danjia);
hashtable.put(daihao,goods);
try{FileOutputStream file=new FileOutputStream("goods.txt");
ObjectOutputStream out=new ObjectOutputStream(file);
out.writeObject(hashtable); out.close();
}
catch(IOException event){}
}
else if(e.getSource()==b_del)
{String daihao1=删除文本框.getText();
try{FileInputStream come_in=new FileInputStream("goods.txt");
ObjectInputStream in=new ObjectInputStream(come_in);
hashtable=(Hashtable)in.readObject(); //////
in.close();
}
catch(ClassNotFoundException event){}
catch(IOException event){}
商品 temp=(商品)hashtable.get(daihao1);
{hashtable.remove(daihao1);}
try{FileOutputStream file=new FileOutputStream("goods.txt");
ObjectOutputStream out =new ObjectOutputStream(file);
out.writeObject(hashtable);//
out.close();
}
catch(IOException event){}
}
//
else if(e.getSource()==b_xun)
{ String aa;
aa=查询文本框.getText();
查询信息文本框.setText(null);
try{FileInputStream come_in=new FileInputStream("goods.txt");
ObjectInputStream in =new ObjectInputStream(come_in);
hashtable=(Hashtable)in.readObject(); ////
in.close();
}
catch(ClassNotFoundException event){}
catch(IOException event){}
商品 a=(商品)hashtable.get(aa);
查询信息文本框.setText(" 代号:"+a.代号+" 名称:"+a.名称+" 库存:"+a.库存+" 单价:"+a.单价);
}
//
else if(e.getSource()==b_xiu)
{ String bb;
bb=代号文本框.getText();
try{FileInputStream come_in=new FileInputStream("goods.txt");
ObjectInputStream in=new ObjectInputStream(come_in);
hashtable=(Hashtable)in.readObject(); //////
in.close();
}
catch(ClassNotFoundException event){}
catch(IOException event){}
商品 temp=(商品)hashtable.get(bb);
{hashtable.remove(bb);}
try{FileOutputStream file=new FileOutputStream("goods.txt");
ObjectOutputStream out =new ObjectOutputStream(file);
out.writeObject(hashtable);//
out.close();
}
catch(IOException event){}
String daihao1=null,mingcheng1=null;int kucun1=0;float danjia1=0.0f;
daihao1=代号文本框.getText();mingcheng1=名称文本框.getText();
kucun1=Integer.parseInt(库存文本框.getText());
danjia1=Float.valueOf(单价文本框.getText()).floatValue();
商品 goods1=new 商品(daihao1,mingcheng1,kucun1,danjia1);
hashtable.put(daihao1,goods1);
try{FileOutputStream file=new FileOutputStream("goods.txt");
ObjectOutputStream out=new ObjectOutputStream(file);
out.writeObject(hashtable); out.close();
}
catch(IOException event){}
}
//
else if(e.getSource()==b_show)
{ 显示区.setText(null);
try{FileInputStream come_in=new FileInputStream("goods.txt");
ObjectInputStream in =new ObjectInputStream(come_in);
hashtable=(Hashtable)in.readObject(); ////
}
catch(ClassNotFoundException event){}
catch(IOException event){}
Enumeration enum=hashtable.elements();
while(enum.hasMoreElements())
{ 商品 te=(商品)enum.nextElement();
显示区.append("商品代号:"+te.代号+" ");
显示区.append("商品名称:"+te.名称+" ");
显示区.append("商品库存:"+te.库存+" ");
显示区.append("商品单价:"+te.单价+" ");
显示区.append("\n ");
}
}
}
}
public class LinkListFour
{public static void main(String args[])
{ ShowWin win=new ShowWin();
win.setSize(400,350);
win.setVisible(true);
win.addWindowListener(new WindowAdapter()
{public void windowClosing(WindowEvent e)
{ System.exit(0);}});
}
}
如果你的产品的种类不是上百万的话,可以非常简单的实现。
每次在你更新库存的时候,数据库锁行,即一种商品(不是锁表哦)。更新前取下实时库存,然后加减你的更新值,看是否超上下限。
超了就不更新(根据你的业务),然后返回一个标记位flag到服务端(比如0是正常,1是超上限,-1超下限制)。服务端维护一个同步的map,存放mapproductid,flag;根据之前返回的标记位,去主动发送消息。也按照每个登录系统的人的session可以做轮询来通知用户。
只要注意2点:1.锁行和更新库存确保一个事务。2.服务端维护的map必须做写入的同步