-
pom.xml
mavenのプロジェクト定義ファイルで
ビルドする際に依存する外部jarファイルの設定やJDKのバージョンを定義します。-
基本設定
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <!-- モデルバージョン --> <modelVersion>4.0.0</modelVersion> <!-- パッケージ名 --> <groupId>jp.co</groupId> <!-- コンテキスト名 --> <artifactId>sample</artifactId> <!-- プロジェクト名 --> <name>Sample</name> <!-- 展開用拡張子 --> <packaging>war</packaging> <!-- バージョン --> <version>1.0.0-BUILD-SNAPSHOT</version> <!-- バージョン情報外だし --> <properties> <java-version>1.6</java-version> <org.springframework-version>3.1.1.RELEASE</org.springframework-version> <org.aspectj-version>1.6.10</org.aspectj-version> <org.slf4j-version>1.6.6</org.slf4j-version> </properties> <!-- 各種設定 --> <dependencies>後述の各種設定をタグ内に記載</dependencies> <!-- ビルド --> <build>省略</build> </project>
「dependencies」タグの中に下記内容を記載していきます。
-
Web開発に必要なライブラリー
<!-- Servlet --> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.1</version> <scope>provided</scope> </dependency> <!-- Tag Library --> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- Logging --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>${org.slf4j-version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>jcl-over-slf4j</artifactId> <version>${org.slf4j-version}</version> <scope>runtime</scope> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>${org.slf4j-version}</version> <scope>runtime</scope> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.15</version> <exclusions> <exclusion> <groupId>javax.mail</groupId> <artifactId>mail</artifactId> </exclusion> <exclusion> <groupId>javax.jms</groupId> <artifactId>jms</artifactId> </exclusion> <exclusion> <groupId>com.sun.jdmk</groupId> <artifactId>jmxtools</artifactId> </exclusion> <exclusion> <groupId>com.sun.jmx</groupId> <artifactId>jmxri</artifactId> </exclusion> </exclusions> <scope>runtime</scope> </dependency>
-
SpringFrameWorkのライブラリー
<!-- Spring --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${org.springframework-version}</version> <exclusions> <!-- Exclude Commons Logging in favor of SLF4j --> <exclusion> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${org.springframework-version}</version> </dependency> <!-- AOP関連(AspectJ) --> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjrt</artifactId> <version>${org.aspectj-version}</version> </dependency> <!-- AOP関連(cglib) --> <dependency> <groupId>cglib</groupId> <artifactId>cglib</artifactId> <version>2.2.2</version> </dependency>
-
基本設定
【SpringMVC】設定ファイルその2
-
src/main/webapp/WEB-INF/spring/root-context.xml
アプリケーションの共通設定として、
ファンクション層(F層:Service)、データ層(D層:Dao)の定義を行う。-
「@Autowire」「@Component」「@Service」のアノテーションを有効にする設定
<context:annotation-config />
-
アノテーションでScan対象とするパッケージを指定
<context:component-scan base-package="jp.co.sample.service" /> <context:component-scan base-package="jp.co.sample.dao" />
上記パッケージにJavaファイルを配置すると、
JavaファイルにSpringの管理を示す「S」マークがつきます。このファイルは共通設定なので、パッケージにcontrollerが
格納されている場所を指定すれば「@Controller」も利用可能ですが、
SpringMVCの考え方として、通常は「@Controller」が属するパッケージは
後述のservlet-context.xmlに定義します。
-
共通設定
<beans:bean id="commonProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean"> <beans:property name="locations" value="classpath:common.properties" /> </beans:bean>
上記記述を行うことでJavaファイル内でcommon.propertiesに
「commonProperties」という名前でアクセスできるようになります。@Autowired private Properties commonProperties;
-
「@Autowire」「@Component」「@Service」のアノテーションを有効にする設定
-
src/main/webapp/WEB-INF/spring/appServlet/servlet-context.xml
プレゼンテーション層(P層:Controller)の定義を行う-
「@Controller」のアノテーションを有効にする設定
<annotation-driven />
-
アノテーションでScan対象とするパッケージを指定
<context:component-scan base-package="jp.co.sample.controller" />
上記パッケージにJavaファイルを配置すると、
JavaファイルにSpringの管理を示す「S」マークがつきます。
-
静的ファイルにHTTP GETリクエストが来た場合の動作定義
<resources mapping="/resources/**" location="/resources/" />
-
コントローラーの処理終了後に呼び出される画面用ファイルの指定
<beans:bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <beans:property name="prefix" value="/WEB-INF/views/" /> <beans:property name="suffix" value=".jsp" /> </beans:bean>
-
「@Controller」のアノテーションを有効にする設定
【SpringMVC】設定ファイルその1
-
src/main/webapp/WEB-INF/web.xml
Springの共通Bean設定ファイルの定義
アプリケーションの共通設定を行う。
root-context.xmlではファンクション層(F層:Service)、データ層(D層:Dao)の定義を行う。<listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/spring/root-context.xml</param-value> </context-param>
SpringMVCのBean設定ファイルの定義
リクエストとサーブレットクラスのマッピングを行う。
servlet-context.xmlではプレゼンテーション層(P層:Controller)の定義を行う。<servlet> <servlet-name>appServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/spring/appServlet/servlet-context.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>appServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>Spring MVCではリクエストはすべて「DispatcherServlet.java」が受け取り、
どのコントローラーを利用するかは「HandlerMapping.java」に委譲している。
マッピングする際に設定値として、「servlet-context.xml」が指定されている。
【SpringMVC】プロジェクト作成
-
Spring MVCプロジェクト作成
「ファイル」-「新規」-「Spring」-「Springプロジェクト」を選択します。
テンプレートは「Spring MVC Project」を選択します。
ここで最初はテンプレートが見つからなかったので、インストールした覚えがあります。
(後で別マシンで検証)インストール場所は自動で下記に配置されました。
「C:\Users\ユーザ名\.m2」パッケージ名は最低3階層まで作成しないとエラーになります。
例:「jp.co.sample」作成後のパッケージ構成は下記の通り。
src/main/java:コントローラーJava配置用 src/main/resources:Spring用設定ファイル配置用(log4.xmlあり) src/test/java:JUnit実施用 src/test/resources:JUnit実施用 src/main/webapp/WEB-INF/views:JSP配置用 src/main/webapp/WEB-INF/classes:プロパティファイル配置用
-
JREシステムライブラリー変更
Eclipseの設定によってはJREシステムライブラリーが1.6になっているので、
プロジェクトを右クリックして「Javaのビルド・パス」で
JREシステムライブラリー1.6を除去して、
JREシステムライブラリー1.7を追加します。
【SpringMVC】導入
-
Spring MVC導入
普段は軽さ重視で「Eclipse 3.7 Indigo」を利用しているのですが、
プラグインの追加で「Eclipse 3.7 Indigo」用の
「Spring Tool Suite」を選択しても
プロジェクト・エクスプローラーの表示がバグったりしたので、
「Eclipse 4.3 Kepler」を利用することにしました。「Eclipse 4.3 Kepler」を立ち上げたら
「ヘルプ」-「Eclipse マーケットプレース」を選択。
「検索」タブで「STS」を入力し、
「Eclipse 4.3 Kepler」用の「Spring Tool Suite」を選択してインストールします。「Spring UAA Integration」はチェックを外してインストールしました。
規約に同意してEclipseを再起動すれば導入完了です。
【Oracle】指定日から連続した日付を取得
SQLで指定日から連続した日付を取得します。
集計画面で日ごとの合計を表示したい場合の親テーブルとして利用できます。
-
例1(ALL_CATALOGを利用)
SELECT TO_DATE('20150101', 'YYYYMMDD') + ROWNUM -1 AS DCOL FROM ALL_CATALOG WHERE TO_DATE('20150101', 'YYYYMMDD') + ROWNUM -1 <= TO_DATE('20150131', 'YYYYMMDD')ORDER BY 1;FROM句には指定日から連続した日付の範囲分の行を持っている必要があります。
今回の例では「ALL_CATALOG」を利用していますが、
そもそも参照権限がない場合もあるので、1~31までのNoだけを持つ空テーブルを利用します。
-
例2(ALL_CATALOGの代わりに1~31までのNoだけを持つ空テーブルを利用)
SELECT TO_DATE('20150101', 'YYYYMMDD') + ROWNUM -1 AS DCOL FROM (SELECT LEVEL id FROM DUAL CONNECT BY LEBEL <= 31) WHERE TO_DATE('20150101', 'YYYYMMDD') + ROWNUM -1 <= TO_DATE('20150131', 'YYYYMMDD')ORDER BY 1;
-
例3(1~31までのNoだけを持つ空テーブルだけを利用)
SELECT SYSDATE + LEVEL AS HIZEKE FROM DUAL CONNECT BY LEBEL <= 31;
【Oracle】順位付け
SQLで点数の高い順位を採番します。
その際、同点の場合、1, 1, 3のように採番します。
SELECT RANK() OVER(ORDER BY 項目 DESC) FROM テーブル名
【Oracle】SQLで表記揺れ
住所の登録システムを作っているときにたまに要件で出てくる表記揺れ。
ひらがなは全て半角カタカナに変換したり、
括弧も全て()に変換したりします。
Oracle10gからの機能であるUTL_I18NパッケージのTRANSLITERATEファンクションを利用します。
下記に例を示しておきます。
テキトーな仕様 全角英数字:全て半角英数字に変換 全角ひらがな、カタカナ:全て半角カタカナに変換 前後の中間の空白:全角、半角問わず削除 全角半角の括弧{}、「」、<>、():全て()に変換 全角記号:半角記号に変換 全角半角のハイフン:全て-に変換
CREATE OR REPLACE FUNCTION CONVERSION_TEST(
IN_CHAR VARCHAR
) RETURN VARCHAR
IS
BEGIN
RETURN
UTL_I18N.TRANSLITERATE(
TRANSLATE(
UPPER(TO_SINGLE_BYTE(REPLACE(REPLACE(IN_CHAR,' '),' ')))
,'{}「」<>()ー-!#$%'
,'()()()()--!#$%'
)
,'kana_hwkatakana')
;
END CONVERSION_TEST;
記号、括弧、ハイフンは全部書くとキリないので、省略しています。
「kana_hwkatakana」の部分は他にも色々あるようです。
【Java】セッションとクッキーについて
セッションとクッキーについてメモ。
-
クッキーについて
-
保存場所
C:\Users\ユーザ名\AppData\Local\Microsoft\Windows\Temporary Internet Files
-
ファイル名
Cookie:ユーザ名@サイト名/
-
ブラウザメモリに保存されているクッキーの値が最優先
ファイルに保存されたクッキーの値を変更しても
ブラウザを閉じない限り、異なるIEで繋いでもブラウザで取得済の
ブラウザメモリのクッキーの値を使用する。
ブラウザを閉じて繋ぎなおすと、ファイルに保存されたクッキーの値を使用する。ただしクッキーの値の変更はツールを使用しないと有効にならない。
手書きで変更しても読み取れずに2番目の動作時にクッキーの値がNULLとなる。
-
保存場所
-
セッションについて
-
保存場所
ブラウザメモリまたはクッキーのファイルに保存。
キー名はJSESSIONIDであり、クッキーの値が優先される。 -
セッションハイジャック
セッションIDはサーバーとやり取りしている中でブラウザが自動でサーバーへ送信しているが、
下記の記述で明示的に直接指定することも可能。変更前
セッションIDはブラウザメモリまたはクッキーの値を自動でサーバーへ送信http://z-area.net/コンテキスト名?request1=test1&request2=test2
変更後
セッションIDはURLの値をサーバーへ送信http://z-area.net/コンテキスト名;jsessionid=12345?request1=test1&request2=test2
12345のセッションIDが正規のユーザのものである場合、
変更後のリクエストは正常に処理される。ログイン画面を表示した時点でセッションIDが採番されるので、
セッションハイジャックを防ぐにはログイン成功後にセッションIDを採番し直す。
-
保存場所
-
ツール
クッキー書き換え:IECookiesView(日本語化可能)
HTTP情報参照:ieHTTPHeaders
【Java】JavaでXML解析
JavaでXMLを解析します。
-
XMLファイル
<?xml version="1.0" encoding="UTF-8"?> <sample> <location> <area name="area1"> <shop type="kanto_shopName1" required="111" /> </area> <area name="area2"> <shop type="sikoku_shopName1" required="222" /> <shop type="sikoku_shopName2" required="333" /> </area> <area name = "area3"> <shop type="kansai_shopName1" required="444" /> <shop type="kansai_shopName2" required="555" /> <shop type="kansai_shopName3" required="666" /> </area> </location> </sample>
-
XMLファイル読取
/* * メイン処理を実行します。 * @param args 引数 */ public static void main(String[] args) { try { File fileObject = new File("src/conf/test.xml"); DocumentBuilder docBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder(); Document document = docBuilder.parse(fileObject); NodeList nodeList = document.getChildNodes(); scanNodes(nodeList); System.out.println("マップサイズ:" + resultMap.size()); for (String key : resultMap.keySet()) { List<Z_XmlAnalyzerBean> list = resultMap.get(key); System.out.print("全体キーは" + key + "@"); for (int i=0; i<list.size(); i++) { Z_XmlAnalyzerBean bean = list.get(i); System.out.print(bean.getKey() + ":" + bean.getValue() + ", "); } System.out.println(""); } } catch (Exception e) { e.printStackTrace(); } }
-
XMLファイル解析
/* * ノードリストを再帰的に解析します。 * @param nodeList ノードリスト */ public static void scanNodes(NodeList nodeList) { for (int i=0; i<nodeList.getLength(); i++) { Node node = nodeList.item(i); if (Node.ELEMENT_NODE == node.getNodeType()) { NamedNodeMap nodeMap = node.getAttributes(); if (nodeMap != null) { for (int j=0; j<nodeMap.getLength(); j++) { if (nodeMap.item(j).getNodeName().equals("name")) { String mapKey = nodeMap.item(j).getNodeValue(); List<Z_XmlAnalyzerBean> list = new ArrayList<Z_XmlAnalyzerBean>(); resultMap.put(mapKey, list); } if (nodeMap.item(j).getNodeName().equals("type")) { String mapValueKey = nodeMap.item(j).getNodeName(); String mapValueValue = nodeMap.item(j).getNodeValue(); System.out.println(mapValueKey + ":" + mapValueValue); Node parentNode = node.getParentNode(); NamedNodeMap parentNodeMap = parentNode.getAttributes(); String parentZokuseiName = parentNodeMap.item(0).getNodeName(); String parentZokuseiValue = parentNodeMap.item(0).getNodeValue(); System.out.println("親:" + parentZokuseiName + "," + parentZokuseiValue); List<Z_XmlAnalyzerBean> list = resultMap.get(parentZokuseiValue); Z_XmlAnalyzerBean bean = new Z_XmlAnalyzerBean(); bean.setKey(mapValueKey); bean.setValue(mapValueValue); list.add(bean); } } } } if (node.hasChildNodes()) { scanNodes(node.getChildNodes()); } } }
-
XML要素格納Bean
public class Z_XmlAnalyzerBean { private String key = null; private String value = null; public String getKey() { return key; } public void setKey(String key) { this.key = key; } public String getValue() { return value; } public void setValue(String value) { this.value = value; } }