在個人的Android開發(fā)的過程中,總會存在缺乏后臺支持的問題俗扇,因為個人開發(fā)者并不會像在公司團隊里那樣方便,有專業(yè)的后臺開發(fā)人員瓦宜。有不少初學者會選擇一些免費的第三方服務器平臺(如Bmob)筐喳,然后一般在這些平臺上都已經規(guī)定好訪問服務器的方式,開發(fā)者并不能根據自己的規(guī)范或需求去定義自己應用的訪問方式悬而,如:
同時呜舒,也因為過度包裝,初學者使用這些平臺時并不能很好地理解Http請求的過程笨奠,所以在個人開發(fā)過程中袭蝗,如果不是為了敏捷開發(fā),一般建議搭建自己的服務器般婆。
搭建自己的服務器到腥,應該說難(畢竟我們的開發(fā)工作并不是后臺開發(fā)),但也可以說不難腺兴,因為我們僅僅是將其作為我們app開發(fā)過程的測試支持左电,并不需要對框架,安全性等問題做深度的研究和探討页响,在此篇文章小編想要簡單介紹一下如何使用Servlet + MySQL快速搭建app的測試后臺:
一篓足、配置開發(fā)環(huán)境
安裝并配置Java開發(fā)環(huán)境
下載eclipse-jee-kepler-SR2-win64,解壓后打開eclipse.exe
-
下載tomcat闰蚕,解壓到指定目錄下栈拖,并在eclipse的Preferences中配置環(huán)境
-
安裝MySQL和對應的查看工具Navicat
-
下載mysql-connector-java(MySQL的JDBC編程驅動程序)并解壓
下載gson.jar(用于JSON數據的格式化與解析工作)并添加為工程的依賴
-
下載花生殼應用
二、初步后臺程序開發(fā)
-
新建一個Dynamic Web Project没陡,工程目錄如下:
在src目錄下新建一個Servlet類涩哟,繼承HttpServlet
public class HelloServlet extends HttpServlet {
@Override
public void init() throws ServletException {
// 初始化(不帶參數)
System.out.println("init without parameters ======");
super.init();
}
@Override
public void init(ServletConfig config) throws ServletException {
// 初始化(帶參數)
System.out.println("init with parameters ======");
super.init(config);
}
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
// 調用次數跟請求次數有關
System.out.println("service ======");
super.service(req, resp);
}
@Override
public void destroy() {
System.out.println("destroy ======");
super.destroy();
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
// 接收程序get請求時執(zhí)行的操作
System.out.println("doGet ======");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
// 接收程序post請求時執(zhí)行的操作
System.out.println("doPost ======");
}
}
Servlet生命周期分為三個階段:
1,初始化階段 —— 調用init()方法
2盼玄,響應客戶請求階段 —— 調用service()方法
3贴彼,終止階段 —— 調用destroy()方法
- 在web.xml中配置Servlet
<servlet>
<servlet-name>HelloServlet</servlet-name>
<servlet-class>com.scnu.zhou.HelloServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloServlet</servlet-name>
<url-pattern>/Login</url-pattern>
</servlet-mapping>
其中url-pattern為訪問Servlet的相對路徑
-
運行后臺程序
選擇工程 -》Run As -》 Run As on Server,選擇tomcat運行
查看訪問結果(控制臺輸出)
到這里一個初步的后臺程序已經寫好了埃儿,接下來就是接收應用的http請求器仗,并進行相應的業(yè)務或數據處理。
三、JDBC編程
-
添加MySQL的JDBC的驅動程序
將mysql-connector-java(解壓后)目錄下的jar文件復制粘貼到項目的WEB-INF/lib目錄下精钮,接著選擇項目 -》右鍵 -》Properties -》Java Build Path -》Libraries -》 Add JARs威鹿,把WEB-INF/lib下的jar添加進去
-
新建數據庫配置文件
選擇Java Resources -》 右鍵 -》 new -》 other -》 General -》 File,新建一個.properties文件轨香,填寫數據庫相關屬性
- driver是JDBC驅動程序名
- dburl是本地數據庫user表的訪問url
- user和password分別是訪問數據庫的用戶名和密碼
- 編寫數據庫連接工具類
public class ConnectionFactory {
private String driver;
private String dburl;
private String user;
private String password;
private Connection conn;
private ConnectionFactory(){
// 解析配置文件
Properties prop = new Properties();
try {
InputStream in = ConnectionFactory.class.getClassLoader()
.getResourceAsStream("dbconfig.properties");
prop.load(in);
} catch (IOException e) {
System.out.println("讀取配置文件出錯");
}
driver = prop.getProperty("driver");
dburl = prop.getProperty("dburl");
user = prop.getProperty("user");
password = prop.getProperty("password");
}
private static class FactoryHolder{
private static final ConnectionFactory instance = new ConnectionFactory();
}
public static ConnectionFactory getInstance(){
return FactoryHolder.instance;
}
public Connection makeConnection(){
// 數據庫連接
try {
Class.forName(driver);
conn = DriverManager.getConnection(dburl, user, password);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return conn;
}
}
- 編寫數據庫操作類Dao(增刪改查)
public interface UserDao {
User getUser(Connection conn, String name, String password) throws SQLException;
void insert(Connection conn, User user) throws SQLException;
void update(Connection conn, User user) throws SQLException;
void delete(Connection conn, User user) throws SQLException;
}
public class UserDaoImpl implements UserDao{
@Override
public User getUser(Connection conn, String name, String password) throws SQLException {
String sql = "SELECT * FROM user WHERE name = '" + name +
"' AND password = '" + password + "'";
Statement st = conn.createStatement();
ResultSet rt = st.executeQuery(sql);
if (rt.next()){
User user = new User();
user.setId(rt.getLong("id"));
user.setName(rt.getString("name"));
user.setPassword(rt.getString("password"));
return user;
}
else{
return null;
}
}
@Override
public void insert(Connection conn, User user) throws SQLException{
PreparedStatement ps = conn.prepareCall(
"INSERT INTO user(name, password) VALUES (?, ?)");
ps.setString(1, user.getName());
ps.setString(2, user.getPassword());
ps.execute();
}
@Override
public void update(Connection conn, User user) throws SQLException{
PreparedStatement ps = conn.prepareCall(
"UPDATE user SET name = ?, password = ? WHERE id = ?");
ps.setString(1, user.getName());
ps.setString(2, user.getPassword());
ps.setLong(3, user.getId());
ps.execute();
}
@Override
public void delete(Connection conn, User user) throws SQLException{
PreparedStatement ps = conn.prepareCall(
"DELETE FROM user WHERE id = ?");
ps.setLong(1, user.getId());
ps.execute();
}
}
四忽你、后臺程序二次開發(fā)
以處理get請求為例,根據請求體中的name和pasword從數據庫中查詢并返回相關數據
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
// 接收程序get請求時執(zhí)行的操作
System.out.println("doGet ======");
// 獲得參數
String name = req.getParameter("name");
String password = req.getParameter("password");
try {
Connection conn = ConnectionFactory.getInstance().makeConnection();
// 查詢用戶數據
UserDao dao = new UserDaoImpl();
User user = dao.getUser(conn, name, password);
// 返回Json數據
PrintWriter pw = resp.getWriter();
pw.println(new Gson().toJson(user));
pw.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
這樣臂容,一個接口就完成了科雳,哈哈,是不是很簡單脓杉,post方法也是一樣的操作炸渡,簡單地來說,我們的應用需要后臺提供接口丽已,讓用戶對后臺的數據進行增刪改查的操作
當然用戶登錄接口可不能這樣寫,該有的安全性還是要的买决,這里只是一個簡單的例子沛婴,你get到了嗎(得意臉)
五、讓我們的移動應用使用這些接口
當然督赤,你會發(fā)現(xiàn)嘁灯,目前這些接口的使用范圍也僅限于本機(電腦),我們的移動應用(手機)上并不能訪問躲舌,也達不到測試的要求丑婿,這里有兩種解決方法,一種是直接將你的后臺部署到服務器上去(如果條件允許的話)没卸,第二種則是將自己的電腦擼成服務器(畢竟只是作為測試服務器)羹奉,下面小編主要介紹第二種方法:
-
下載花生殼免費版應用
-
點擊內網穿透
-
添加映射
內網主機:進入網絡和共享中心-》點擊電腦當前的網絡-》進入詳細信息 -》 IPv4地址就是需要填寫的內網主機
內網端口:可任意填寫(1-65535)
然后我們就可以在外網訪問我們的接口了:
哈哈,有需求才有學習的動力约计,雖然本篇講的是Servlet+MySQL搭建的后臺诀拭,并沒有使用其他高效的框架,這也是我們前端應用開發(fā)者對后臺理解的第一步煤蚌,希望對大家 有所幫助耕挨。