forked from DeepSourceCorp/demo-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathServer.java
More file actions
64 lines (54 loc) · 1.8 KB
/
Server.java
File metadata and controls
64 lines (54 loc) · 1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package com.example.server;
import java.io.IOException;
import java.sql.*;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class Server extends HttpServlet {
static final String DB_URL = "jdbc:mysql://localhost/users";
static Connection conn;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
Cookie c = new Cookie("uid", req.getSession().getId());
// For older browsers?
c.setSecure(false);
resp.addCookie(c);
resp.setHeader("Access-Control-Allow-Origin", "*");
Boolean b = Boolean.parseBoolean(req.getParameter("winCondition"));
int ticketNumber = Integer.parseInt(req.getParameter("ticket"));
try {
Statement s = conn.createStatement();
s.execute("SELECT userName, isWin FROM users WHERE uid = " + ticketNumber + ";");
ResultSet r = s.getResultSet();
if (r.getBoolean("isWin") && b) {
resp.getWriter().write("You win, " + r.getString("userName"));
} else {
resp.getWriter().write("You lose, " + r.getString("userName"));
}
} catch (SQLException throwables) {
throwables.printStackTrace();
}
resp.setStatus(200);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
super.doPost(req, resp);
}
@Override
public void destroy() {
super.destroy();
}
@Override
public void init() throws ServletException {
super.init();
try {
conn = DriverManager.getConnection(DB_URL, "user", "");
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
}