追記
スーパクラスの"userid"をサブクラスで利用したいです。
Java
1 protected int userid; 2 protected String username; 3 protected String roll; 4 5 public CalenderAccess() { 6 super(); 7 } 8 9 @Override 10 protected void doGet(HttpServletRequest request, HttpServletResponse response) 11 throws ServletException, IOException { 12 response.setContentType("text/html; charset=UTF-8"); 13 14 /* ユーザー情報を取り出す */ 15 HttpSession session = request.getSession(false); 16 Object tmp = session.getAttribute("username"); 17 18 if (tmp == null) { 19 this.username = ""; 20 } else { 21 this.username = (String) tmp; 22 } 23 24 tmp = session.getAttribute("userid"); 25 if (tmp == null) { 26 this.userid = 0; 27 } else { 28 this.userid = Integer.parseInt((String) tmp); 29 } 30 31 tmp = session.getAttribute("roll"); 32 if (tmp == null) { 33 this.roll = ""; 34 } else { 35 this.roll = (String) tmp; 36 }
Java
1class CalendarBasic extends CalenderAccess { 2 3//途中省略 4 5 protected String ScehduleVew(int year, int month, int date) { 6 System.out.println("userid=" + super.userid); 7 8 String schedule = null; 9 try { 10 scheduleDao dao = new scheduleDao(); 11 schedule = dao.scheduleVew(year, month, date, super.userid); 12 } catch (SQLException e) { 13 e.printStackTrace(); 14 } 15 return schedule; 16 } 17} 18
いつもお世話になります。
スーパクラスのフィールド変数に値を代入し、サブクラスのメソッドで、スーパクラスのフィールド変数を利用しようとしていますが、代入した値が0になってしまします。
原因が見つからず困っている状況です。
ご教授頂けないでしょうか。
Java
1package schedule; 2 3import java.io.IOException; 4 5import javax.servlet.ServletException; 6import javax.servlet.annotation.WebServlet; 7import javax.servlet.http.HttpServlet; 8import javax.servlet.http.HttpServletRequest; 9import javax.servlet.http.HttpServletResponse; 10import javax.servlet.http.HttpSession; 11 12/** 13 * Servlet implementation class CalenderAccess 14 */ 15@WebServlet("/schedule/CalenderAccess") 16public class CalenderAccess extends HttpServlet { 17 private static final long serialVersionUID = 1L; 18 19 protected int userid; 20 protected String username; 21 protected String roll; 22 23 public CalenderAccess() { 24 super(); 25 } 26 27 @Override 28 protected void doGet(HttpServletRequest request, HttpServletResponse response) 29 throws ServletException, IOException { 30 response.setContentType("text/html; charset=UTF-8"); 31 32 /* ユーザー情報を取り出す */ 33 HttpSession session = request.getSession(false); 34 Object tmp = session.getAttribute("username"); 35 36 String username; 37 if (tmp == null) { 38 username = ""; 39 } else { 40 username = (String) tmp; 41 } 42 43 tmp = session.getAttribute("userid"); 44 int userid; 45 if (tmp == null) { 46 userid = 0; 47 } else { 48 userid = Integer.parseInt((String) tmp); 49 } 50 51 tmp = session.getAttribute("roll"); 52 String roll; 53 if (tmp == null) { 54 roll = ""; 55 } else { 56 roll = (String) tmp; 57 } 58 59 System.out.println("Auserid" + userid); 60 61 request.setAttribute("username", username); 62 request.setAttribute("roll", roll); 63 request.setAttribute("userid", userid); 64 65 /* カレンダー作成 */ 66 CalendarBasic.prepData(request); 67 68 request.getRequestDispatcher("schedule/Calender.jsp").forward(request, response); 69 } 70}
Java
1package schedule; 2 3import java.sql.SQLException; 4import java.util.Calendar; 5 6import javax.servlet.http.HttpServletRequest; 7 8class CalendarBasic extends CalenderAccess { 9 10 protected static void prepData(HttpServletRequest request) { 11 // カレンダーの取得 12 Calendar cal = Calendar.getInstance(); 13 14 // 年が設定されていれば、その値を取得。そうでなければ、今年の年号を入れる 15 String param = request.getParameter("year"); 16 System.out.println("19 year=" + param); 17 if (param == null || param.length() == 0) { 18 request.setAttribute("year", cal.get(Calendar.YEAR)); // 現在の年 19 } else { 20 request.setAttribute("year", request.getParameter("year")); // 現在の年 21 } 22 // 月が設定されていれば、その値を取得。そうでなければ、今の月を入れる 23 param = request.getParameter("month"); 24 System.out.println("27 Month=" + param); 25 if (param == null || param.length() == 0) { 26 request.setAttribute("month", cal.get(Calendar.MONTH) + 1); // 現在の月 27 } else { 28 request.setAttribute("month", request.getParameter("month")); // 与えらられた月 29 } 30 int year = Integer.parseInt(request.getAttribute("year").toString()); 31 int month = Integer.parseInt(request.getAttribute("month").toString()); 32 33 // 月初めの曜日(日-> 1) 34 cal.set(year, month - 1, 1); 35 int startday = cal.get(Calendar.DAY_OF_WEEK); 36 // 月末の日付 37 cal.add(Calendar.MONTH, 1); 38 cal.add(Calendar.DATE, -1); 39 int lastday = cal.get(Calendar.DATE); 40 // カレンダーのデータを作成する 41 int date = 1; 42 int maxday = 6 * 7; 43 44 CalendarBasic cb = new CalendarBasic(); 45 String ScehduleVew = cb.ScehduleVew(year, month, date); 46 47 System.out.println("45 year=" + year); 48 System.out.println("45 month=" + month); 49 System.out.println("45 date=" + date); 50 System.out.println("46 startday=" + startday); 51 System.out.println("47 lastday=" + lastday); 52 System.out.println("48 maxday=" + maxday); 53 System.out.println("48 schedule=" + ScehduleVew); 54 55 request.setAttribute("date", date); 56 request.setAttribute("startday", startday); 57 request.setAttribute("lastday", lastday); 58 request.setAttribute("maxday", maxday); 59 request.setAttribute("scheule", ScehduleVew); 60 61 return; 62 } 63 64 protected String ScehduleVew(int year, int month, int date) { 65 System.out.println("userid=" + super.userid); 66 67 String schedule = null; 68 try { 69 scheduleDao dao = new scheduleDao(); 70 schedule = dao.scheduleVew(year, month, date, super.userid); 71 } catch (SQLException e) { 72 e.printStackTrace(); 73 } 74 return schedule; 75 } 76}
回答2件
あなたの回答
tips
プレビュー