JSP 21. Fancytree
復習する
Cookieセッション
--Cookieはサーバ側
特殊文字を含む符号化
マーシャルリン
jsonとして保存し、marshalling unmarshalling
explorer
2020.12.16水曜日
https://github.com/mar10/fancytree/wiki
data:image/s3,"s3://crabby-images/e85f9/e85f9d6a534504223760f11697c81b55bf5a73b0" alt=""
画像の一部
data:image/s3,"s3://crabby-images/aec7f/aec7f688d8313d826284178ba983778517d14e00" alt=""
explorer.jsp
data:image/s3,"s3://crabby-images/7d081/7d08120455414b2bac2e08f9b6d4ed0c460fbf47" alt=""
その後、非同期要求データ
ServerSideExplorerServlet.java
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//컨텍스트루트아래에 어떤 폴더들이 있는지 필요함
String base = req.getParameter("base"); //클라이언트가 원하는 경로의 값
if(StringUtils.isBlank(base))
base = "/"; //루트
List<FileWrapper> list = makeData(base); //childern 만드는
// File[] list = file.listFiles();
//accept에 json여부에 따라 경로 달라지게
String accept = req.getHeader("Accept");
//대소문자 구분 없음 .json포함되어있는지 보기 (json이 헤더에 있느냐)
if(StringUtils.containsIgnoreCase(accept, "json")) {
//마임셋팅
resp.setContentType("application/json;charset=UTF-8");
//마샬링,직렬화 - 응답데이터 기록할 stream 생성
try(
PrintWriter out = resp.getWriter();
){
ObjectMapper mapper = new ObjectMapper();
mapper.writeValue(out, list);
}
//2020.12.16 수요일 json포함된 데이터는 마샬링해서 내보낼 수 있도록 수정
}else {//헤더에 json이 없으면 -- explorer.jsp에서 동기방식으로 처리했을때 사용했음
req.setAttribute("children", list); //이동하는 경우에만 scope 사용
String logicalView = "others/explorer"; //tiles.xml에 가봐서 definition name확인
req.getRequestDispatcher("/"+logicalView+".tiles").forward(req, resp);
}
}
ファン図面にはファイルオブジェクトが1つしかありません
panshetleyというお客様がpanshetleyノードを使用したいと思っています.
data:image/s3,"s3://crabby-images/d96d1/d96d1602274032ee2bd10600951dab1fcdd7ba89" alt=""
https://wwwendt.de/tech/fancytree/doc/jsdoc/Fancytree.html
data:image/s3,"s3://crabby-images/e59fe/e59fe8115458b3433cdbf06e14ebd2e8e44b983a" alt=""
https://wwwendt.de/tech/fancytree/doc/jsdoc/FancytreeNode.html
data:image/s3,"s3://crabby-images/4efaa/4efaa3c7e524bbf169da6126d2b36bb9f5ed7f40" alt=""
data:image/s3,"s3://crabby-images/e4077/e407776f58aecef0164234ec848a4e40c1357c65" alt=""
nodeはファイルコンセプト
data:image/s3,"s3://crabby-images/fee57/fee573cee56d4d35b9c942f91bf7cc740f8a556e" alt=""
data:image/s3,"s3://crabby-images/843cb/843cb6e2b29a1bdab0108568d8314860364551ea" alt=""
https://wwwendt.de/tech/fancytree/demo/
Lazyをtrueに設定
ServerSideExplorerServlet.java
ここにTreeSetを書き込みます(以前はソート順がありませんでした)
CTRL+SHIFT+T>SortedSetを開く
data:image/s3,"s3://crabby-images/1eb59/1eb597003dc65bc8f36d7140f7f97367238a04e0" alt=""
data:image/s3,"s3://crabby-images/e341c/e341c4628e8b31c99a6a9c720035663d2e7b083b" alt=""
data:image/s3,"s3://crabby-images/aeaf4/aeaf4b174e9135690983f772a8684f0c2a3d30db" alt=""
ServerSideExplorerServlet.java
Treeset
private List<FileWrapper> makeData(String base) {
String realPath = application.getRealPath(base);
File file = new File(realPath);
//어댑티 - 폴더 순서과정 코드
Set<String> resourcePaths = application.getResourcePaths(base); //children에 대한 가상경로, set이면 순서가 없음, 인덱스와키가 없음 ,set은 중복을 허용하지 않는다
List<FileWrapper> list = new ArrayList<>();
if(resourcePaths!=null) {
//어댑터
TreeSet<String> treeSet = new TreeSet<>(resourcePaths); //어댑티를 넘겨줘야한다 , 이름을 기준으로 정렬해버림 우리만의 정렬구조를 따로 잡아야한다 폴더 다음에 파일순으로
for(String relativePath : treeSet) {
String fileRealPath= application.getRealPath(relativePath); //가상경로 컨텍스트패스 이후 경로만 갖고있다
File child = new File(fileRealPath);
list.add(new FileWrapper(child, relativePath));
}
Collections.sort(list);//정렬조건 사용
}
return list;
}
data:image/s3,"s3://crabby-images/6d672/6d672571b5b91ede75b2ece57616c92573de8a45" alt=""
UIでは、名前順に並べられています
フォルダを先に上げましょう.
FileWrapper.java
data:image/s3,"s3://crabby-images/81e6f/81e6f32538511a0c1fd83fd3d054d877c15f8058" alt=""
Compareable implements(ソート機能)
@Override
public int compareTo(FileWrapper o) {//o라는 녀석과 비교
int ret = 0;
//폴더를 앞으로 파일은 뒤로
if(this.folder && !o.isFolder()) {
ret = -1;
}else if(!this.folder && o.isFolder()) {
//나는 파일인데 상대방이 폴더야
ret = 1;
}else {
//둘다 폴더이거나 둘다 파일이거나 , 이름으로 순서 결정 알파벳 대소문자 비교
ret = this.title.toLowerCase().compareTo(o.getTitle());
}
return ret;//음수면 내가 앞으로 양수면 내가 뒤로 간다는 뜻
}
ServerSideExplorerServlet.java
data:image/s3,"s3://crabby-images/88179/88179a4dba275c942c489efe0dd517a65799992f" alt=""
Webappで11個のフォルダを作成してブラウザをリフレッシュするのでfancytreeでは11個のフォルダは作成されません
https://github.com/mar10/fancytree/wiki/ExtFilter
https://wwwendt.de/tech/fancytree/demo/#sample-ext-filter.html
2つのサイトリファレンス->フィルタを適用して検索
Reference
この問題について(JSP 21. Fancytree), 我々は、より多くの情報をここで見つけました https://velog.io/@zhyun1220/JSP-21テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol