#NumberformatException #if #문자 #1글자비교  #equals #MyBatis #JAVA #자바

ex 1)
<if test="stringValue == 'Y'">
</if>

ex 2)
<if test="condition.equals('Y')">
</if>


지금처럼 한 글자를 다이나믹쿼리 IF  안에서 비교할 때

java.lang.NumberFormatException: For input string: "Y" 에러 또는

비교가 되지 않을 수 있다. (인식 불가 혹은 오작동 가능성도 있음)
결론적으로 위 현상은 myBatis 문제는 아니고

OGNL(Object Graph Navigation Language) 의 문제이다.

OGNL 인터프리터에서는 위 구문의 'Y' 를 char 형으로 인식하고,
'YY' 나 "Y" 는 String으로 인식한다. (따옴표를 잘보자)
그래서  이와 같은 구문을 비교할 때 
 NumberFormat으로 비교를 시도하여 Exception이 발생한다.
이유는 java의 char형은 실제로 문자의 코드값을 저장하기 때문이다.

그래서 아래와 같은 형변환이 가능하다.

char y = 'Y';
int code = (int)y; // code에는 Y의 코드값인 89가 저장된다

그래서 위와 같은 상황을 피하기 위해서는 다음과 같은 해결책이 존재한다.

1. <if test='stringValue == "Y"'> – 쌍따옴표와 홑따옴표의 위치를 변경

2. <if test="stringValue == &quot;Y&quot;"> – 쌍따옴표를 HTML 코드로 변경

3. <if test="stringValue == 'Y'.toString()"> – toString() 함수를 사용해 String 형으로 변환

4. 함수 생성 (equals 함수를 새로 생성하고 가져다 쓰는 방법 )




http://cofs.tistory.com/97 에서 설명하고 있는
함수를 생성해서
사용방법을 참조하여 equals함수를 재정의

1번과 4번 방법을 추천한다.


출처: https://cofs.tistory.com/96 [CofS]

Posted by 홍반장水 홍반장水

댓글을 달아 주세요

IoT 개발 위한 3가지 프로그래밍 언어 "C, 자바, 파이썬"

10년 전만 해도, 사용량에 따라 성능을 개선할 수 있는 에어컨을 사용한다거나 자율적으로 교통을 항해할 수 있는 자율주행차(self-driving cars)를 운행해 볼 수 있다고 상상할 수 있었을까. 하지만 둘 다 현실이 됐다. 이러한 스마트한 기기들이 어떻게 작용하는지 궁금하다면, 그 대답은 사물 인터넷(Internet of Things, IoT)이다.

잘 알다시피, IoT 기술의 목적은 데이터를 측정, 수집 및 분석해 더 나은 고객 경험(customer experience)을 제공하고 제품의 품질을 높이는 것이다. 다시 말해, IoT 기능은 도시, 집, 그리고 사업을 더 나아지게 만드는 것이다.

IoT 기술의 세 가지 단계인 측정(measurement), 수집(collection), 분석(analysis)은 각각 제약 조건이 서로 다른 작업 환경을 가지고 있다. 일례로  데이터는 기능이 제한된 디바이스의 센서를 통해 측정된다. 그런 다음 이 데이터는 스마트폰의 앱과 같은 게이트웨이(gateway)와 디바이스 보다 완전히 다른 컴퓨팅 성능을 가진 소형 콘솔(console)을 사용해 집계되고 전송된다. 이 데이터는 클라우드를 이용해 저장 및 분석된다.

따라서 소프트웨어 개발 단계마다 IoT 프로그래밍 언어가 다를 수 있다. 실제 이클립스 재단(Eclipse Foundation)이 2018년 1월부터 3월까지 502명이 참여한 IoT 개발자 설문조사를 진행했는데, 설문조사에 따르면 개발자들은 C, C++, Java, JavaScript, Python, PHP와 같은 몇 개의 다른 IoT용 프로그래밍 언어를 사용하는 것으로 나타났다. 특히 이번 조사에 따르면 자바가 66.5%의 인기를 얻으며 전반적인 리더라는 것을 보여준다. C는 56.9%로 그 뒤를 이었고, 자바스크립트(JS)와 파이썬(Python)이 각각 47.1%와 46%로 뒤를 이었다. 이클리스 재단은 2015년부터 전 세계 IoT 개발업체에서 일하는 개발자들을 대상으로 이 분야의 전반적인 환경, 과제, 동향을 파악해 왔다.

이와 관련 최근 IoT 전문매체 아이오티포올닷컴(iotforall.com)은 C, 자바, 파이썬 등 IoT 개발을 위한 상위 3개 프로그래밍 언어에 대해 분석해 보도했다.

먼저 C 언어는 디바이스 수준에서 컴퓨팅 파워(computing power, 연산력)은 상당히 제한적이다. 낮은 수준의 코드(즉, 하드웨어 레이어에 가까운 코드)를 쓰는 데 이상적이고 프로세싱 파워(processing power, 처리능력)이 많이 필요하지 않으며 RAM과 직접 작동할 수 있다. 또한 C는 마이크로컨트롤러 프로그래밍(microcontroller programming)의 공통 언어로, 센서 및 게이트웨이 하드웨어 레이어 애플리케이션의 경우 쉽게 처리할 수 있다. 하지만 C는 매우 낮은 수준의 언어이기 때문에 개발자들이 능숙하지 않으면 C의 신택스(syntax, 구문)이 빠르게 어수선해지고 흐트러질 수 있다.

다음으로 자바는 프로그래밍 세계에서 널리 사용되고 가르쳐진다. IoT 애플리케이션에서는 자바 가상 머신(Java Virtual Machine, JVM) 코드를 어떤 칩으로도 전송할 수 있다. 이 코드는 스마트폰과 서버처럼 JVM이 흔한 곳에서 사용될 수 있다. IoT 소프트웨어에 이상적으로 적합하도록 작은 기계에도 사용할 수 있다. 이밖에 자바 언어는 IoT를 위한 객체지향 프로그래밍 언어(object-oriented programming language)다. 또한 IoT 응용프로그램에 유용한 내장 기능을 가지고 있고 휴대성이 뛰어나며 하드웨어 제한이 없다.

마지막으로 파이썬은 고급 스크립팅(scripting) 언어로서의 입지를 구축해 가고 있다. 파이썬은 많은 유용한 라이브러리(library, 파일들의 모음)을 가지고 있고, 더 적은 수의 코드 행수(lines of code)로 더 많은 것들을 할 수 있다. 이 때문에IoT 시스템 데이터 분석에 이상적이다. 또한 파이썬의 소스 코드는 신택스가 깨끗하기 때문에 컴팩트하고 알기 쉽다. 아울러 배우기 쉽고, 널리 사용되며, 강하게 지지된다. 이밖에 똑같이 복잡한 코드베이스(codebases)를 유지하지 않고도 복잡한 데이터 스트림(data streams)을 관리하고 구성할 수 있다. 파이썬은 계산 수요(computational demand)가 적당히 낮은 단순한 모듈형 프로젝트(modular projects)로 인기를 얻고 있다.

한편 매체는 "IoT 사용이 증가함에 따라 제품 성능, 도전, 기회에 대한 더 많은 데이터가 생성될 것이다. 그리고 어떤 프로그래밍 언어가 IoT 제품이나 서비스에 더 잘 적용되는지 더 잘 이해할 수 있을 것이다"면서 "이 데이터를 분석하면 IoT 개발의 특정 시나리오에 가장 적합한 시스템 레벨 프로그래밍 언어를 더 잘 이해할 수 있다. 그때까지 IoT 소프트웨어 개발은 여러 언어로 진행될 전망이다"고 전했다.

 

https://www.codingworldnews.com/229

 

IoT 개발 위한 3가지 프로그래밍 언어 "C, 자바, 파이썬" - 코딩월드뉴스

10년 전만 해도, 사용량에 따라 성능을 개선할 수 있는 에어컨을 사용한다거나 자율적으로 교통을 항해할 수 있는 자율주행차(self-driving cars)를 운행해 볼 수 있다고 상상할 수 있었을까. 하지만 둘 다 현실이 됐다. 이러한 스마트한...

www.codingworldnews.com

 

Posted by 홍반장水 홍반장水

댓글을 달아 주세요

#java #오늘 #일자 #string #format #YYYYMMDD

오늘 날짜를 문자 YYYYMMDD  포맷으로 나오게 하는 방법

import java.util.Calendar;

import java.text.SimpleDateFormat;



public class testToday{

    public static void main(String args[]){

        SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");

        Calendar c1 = Calendar.getInstance();

	 String strToday = sdf.format(c1.getTime());



        System.out.println("Today=" + strToday);

    }

}
Posted by 홍반장水 홍반장水

댓글을 달아 주세요

#iBATIS 와 #MyBatis 의 차이

iBATIS

MyBatis

태그

설명

태그

설명

 <isEqual>

 property 값이 같을때만 쿼리 실행 

 <if>와

<choose>, <when>, <otherwise>

 일반 개발언어의 

if or if ~ else와 동일

 <isNotEqual>

 property 값이 같지 않을 때만 쿼리 실행 

 <isGreaterThan>

 property 값이 비교값보다 클 경우 쿼리 실행 

<isGreaterEqual> 

 property 값이 비교값보다 같거나 클 경우 쿼리 실행

 <isLessEqual>

 property 값이 비교값보다 작거나 같을경우 쿼리 실행

 <isPropertyAvailable>

 property 값이 유효할 경우 쿼리 실행

 <isNotPropertyAvailable>

 property 값이 유효하지 않을 경우 쿼리 실행

 <isNull>

 property 값이 null일 경우 쿼리 실행 

<isNotNull> 

 property 값이 null이 아닐 경우 쿼리 실행 

<isEmpty> 

 property 값이 비어있을경우 쿼리 실행

<isNotEmpty> 

 property 값이 비어있지 않을경우 쿼리 실행 

 <isParameterPresent>

 parameter가 있을경우 쿼리 실행

<isNotParameterPresent> 

 parameter가 없을경우 쿼리 실행

<iterate> 

 배열 타입의 파라미터를 받을 때 활용

 <foreach>

 배열 타입의 파라미터를 받을 때 활용 

<dynamic> 

 하위 태그에 일치하는 내용이 존재할 경우   where절을 붙인다.

<where>, <trim> 

 iBATIS의 <dynamic>과 같이 조건에 따라 where절을 추가할 때 사용

 

 

 <set>

 동적으로 update 구문을 만들 때 사용

   

 <bind>

 변수를 생성하는 태그 

 


  

4       iBatis


  

  

MyBatis 


  

비고


  

  

com.ibatis.*


  

  

org.apache.ibatis.*


  

  

패키지 구조 변경


  

  

SqlMapConfig


  

  

Configration


  

  

용어변경


  

  

sqlMap


  

  

mapper


  

  

용어변경


  

  

sqlMapClient


  

  

sqlSession


  

  

구문대체


  

  

rowHandler


  

  

resultHandler


  

  

구문대체


  

  

resultHandler


  

  

SqlSessionFactory


  

  

구문대체


  

  

parameterMap, parameterClass


  

  

parameterType


  

  

속성 통합


  

  

resultClass


  

  

resultType


  

  

용어변경


  

  

#var#


  

  

#{var}


  

  

구문대체


  

  

$var$


  

  

${var}


  

  

구문대체


  

  

<isEqual> , <isNull>


  

  

<if>


  

  

구문대체


  

.

Posted by 홍반장水 홍반장水

댓글을 달아 주세요

[JSTL] Tag가 jsp 화면에 그대로 노출될 경우, escapeXml  

JSTL로  처리를 할 때, 태그가 적용이 안되고 화면에 그대로 노출이 될 때가 있다.

기본적으로 escapeXml 이라는 값이 true로 처리가 되고, 이 속성은 <, > 와 같은 값들을 <, > 등으로 변경하여 화면에 뿌려주게 된다.

하지만, 태그를 원하는 대로 뿌려줘야 할 경우도 존재하니 이럴 경우 escapeXml="false" 처리를 해주면 된다.

<c:out value="${값}" />
<c:out value="${값}" escapeXml="false" />
 
Posted by 홍반장水 홍반장水

댓글을 달아 주세요

[JSTL] 한자리 숫자 앞에 0붙이기, addZero

<c:forEach var="c" items="${contents.content}" varStatus="status">
    <fmt:formatNumber var="no" minIntegerDigits="2" value="${status.count}" type="number"/>
     ${no}
</c:forEach>
Posted by 홍반장水 홍반장水
TAG addzero, Java, jsp, JSTL

댓글을 달아 주세요

[JAVA] HttpURLConnection로 REST API 호출하기 

public void post(String strUrl, String jsonMessage){
		try {
			URL url = new URL(strUrl);
			HttpURLConnection con = (HttpURLConnection) url.openConnection();
			con.setConnectTimeout(5000); //서버에 연결되는 Timeout 시간 설정
			con.setReadTimeout(5000); // InputStream 읽어 오는 Timeout 시간 설정
			con.addRequestProperty("x-api-key", RestTestCommon.API_KEY); //key값 설정

			con.setRequestMethod("POST");

            //json으로 message를 전달하고자 할 때 
			con.setRequestProperty("Content-Type", "application/json");
			con.setDoInput(true);  // InputStream으로 응답 헤더와 메시지를 읽어들이겠다는 옵션
			con.setDoOutput(true); //POST 데이터를 OutputStream으로 넘겨 주겠다는 설정 
			con.setUseCaches(false);
			con.setDefaultUseCaches(false);

			OutputStreamWriter wr = new OutputStreamWriter(con.getOutputStream());
			wr.write(jsonMessage); //json 형식의 message 전달 
			wr.flush();

			StringBuilder sb = new StringBuilder();
			if (con.getResponseCode() == HttpURLConnection.HTTP_OK) {
				//Stream을 처리해줘야 하는 귀찮음이 있음.
				BufferedReader br = new BufferedReader(
						new InputStreamReader(con.getInputStream(), "utf-8"));
				String line;
				while ((line = br.readLine()) != null) {
					sb.append(line).append("\n");
				}
				br.close();
				System.out.println("" + sb.toString());
			} else {
				System.out.println(con.getResponseMessage());
			}
		} catch (Exception e){
			System.err.println(e.toString());
		}
}

 

// 요청할 파라미터의 정보를 입력한다.
String body = "id=asdf&pass=asdf";

// URL클래스의 생성자로 주소를 넘겨준다.
URL u = new URL( 주소 );

// 해당 주소의 페이지로 접속을 하고, 단일 HTTP 접속을 하기위해 캐스트한다.
HttpURLConnection  huc = (HttpURLConnection) u.openConnection();

// POST방식으로 요청한다.( 기본값은 GET )
huc.setRequestMethod("POST");

//InputStream으로 응답 헤더와 메시지를 읽어들이겠다는 옵션을 정의한다.
   huc.setDoInput(true);

// OutputStream으로 POST 데이터를 넘겨주겠다는 옵션을 정의한다.
   huc.setDoOutput(true);

// 요청 헤더를 정의한다.( 원래 Content-Length값을 넘겨주어야하는데 넘겨주지 않아도 되는것이 이상하다. )
   huc.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");

// 새로운 OutputStream에 요청할 OutputStream을 넣는다.
   OutputStream os = huc.getOutputStream();

// 그리고 write메소드로 메시지로 작성된 파라미터정보를 바이트단위로 "EUC-KR"로 인코딩해서 요청한다.

// 여기서 중요한 점은 "UTF-8"로 해도 되는데 한글일 경우는 "EUC-KR"로 인코딩해야만 한글이 제대로 전달된다.
   os.write( body.getBytes("euc-kr") );

// 그리고 스트림의 버퍼를 비워준다.
   os.flush();

// 스트림을 닫는다.
os.close();

// 응답받은 메시지의 길이만큼 버퍼를 생성하여 읽어들이고, "EUC-KR"로 디코딩해서 읽어들인다.
BufferedReader br = new BufferedReader( new OutputStreamReader( huc.getInputStream(), "EUC-KR" ), huc.getContentLength() );

String buf;

// 표준출력으로 한 라인씩 출력
while( ( buf = br.readLine() ) != null ) {
    System.out.println( buf );
}

// 스트림을 닫는다.
br.close();

 

Posted by 홍반장水 홍반장水

댓글을 달아 주세요

[JSTL core] [c:forEach] varStatus를 활용한 변수

forEach문은 아래와 같이 활용한다.

<c:foreach items="${리스트가 받아올 배열이름}"
           var="for문 내부에서 사용할 변수"
           varStatus="상태용 변수">

	// 반복해서 표시할 내용 혹은 반복할 구문

</c:foreach>

이 때, 상태용 변수를 status라고 지정했다면 아래와 같이 활용할 수 있다.

 

${status.current} 현재 for문의 해당하는 번호

${status.index} 0부터의 순서

${status.count} 1부터의 순서

${status.first} 첫 번째인지 여부

${status.last} 마지막인지 여부

${status.begin} for문의 시작 번호

${status.end} for문의 끝 번호

${status.step} for문의 증가값

<c:foreach items="${list}" var="list" varStatus="status">
	<c:out value="${status.index}" /> / <c:out value="${status.end}" />
</c:foreach>
Posted by 홍반장水 홍반장水
TAG foreach, Java, JSTL

댓글을 달아 주세요

Hide the navigation bar - Android

https://developer.android.com/training/system-ui/navigation#behind

 

Hide the navigation bar  |  Android Developers

This lesson describes how to hide the navigation bar, which was introduced in Android 4.0 (API level 14). Even though this lesson focuses on hiding the navigation bar, you should design your app to hide the status bar at the same time, as described in Hidi

developer.android.com

This lesson describes how to hide the navigation bar, which was introduced in Android 4.0 (API level 14).

Even though this lesson focuses on hiding the navigation bar, you should design your app to hide the status bar at the same time, as described in Hiding the Status Bar. Hiding the navigation and status bars (while still keeping them readily accessible) lets the content use the entire display space, thereby providing a more immersive user experience.

You can hide the navigation bar using the SYSTEM_UI_FLAG_HIDE_NAVIGATION flag. This snippet hides both the navigation bar and the status bar:

View decorView = getWindow().getDecorView();
// Hide both the navigation bar and the status bar.
// SYSTEM_UI_FLAG_FULLSCREEN is only available on Android 4.1 and higher, but as
// a general rule, you should design your app to hide the status bar whenever you
// hide the navigation bar.
int uiOptions = View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
              | View.SYSTEM_UI_FLAG_FULLSCREEN;
decorView.setSystemUiVisibility(uiOptions);
Posted by 홍반장水 홍반장水

댓글을 달아 주세요

jsp 현재 날짜, 일주일전 날짜, 한달 전 날짜 구하기.

currentCalendar.add 부분에 -값이 아닌 +값을 대입하면 현재 이후의 날짜를 구할 수 있지요.

 

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page import="java.text.DecimalFormat" %>
<%@ page import="java.text.SimpleDateFormat" %>
<%@ page import="java.util.Calendar" %>

<%
    DecimalFormat df = new DecimalFormat("00");
    Calendar currentCalendar = Calendar.getInstance();

  //현재 날짜 구하기
    String strYear   = Integer.toString(currentCalendar.get(Calendar.YEAR));
    String strMonth  = df.format(currentCalendar.get(Calendar.MONTH) + 1);
    String strDay   = df.format(currentCalendar.get(Calendar.DATE));
    String strDate = strYear + strMonth + strDay;

  //일주일 전 날짜 구하기
    currentCalendar.add(currentCalendar.DATE, -7);
    String strYear7   = Integer.toString(currentCalendar.get(Calendar.YEAR));
    String strMonth7  = df.format(currentCalendar.get(Calendar.MONTH) + 1);
    String strDay7   = df.format(currentCalendar.get(Calendar.DATE));
    String strDate7 = strYear7 + strMonth7 + strDay7;

  //한달 전 날짜 구하기
    currentCalendar.add(currentCalendar.DATE, -24);
    String strYear31   = Integer.toString(currentCalendar.get(Calendar.YEAR));
    String strMonth31  = df.format(currentCalendar.get(Calendar.MONTH) + 1);
    String strDay31   = df.format(currentCalendar.get(Calendar.DATE));
    String strDate31 = strYear31 + strMonth31 + strDay31;
%>

<!-- 현재날짜 -->
<c:set var="nowdate" value='<%=strDate%>' />
<!-- 일주일전 -->
<c:set var="nowdate7" value='<%=strDate7%>' />
<!-- 한달전 -->
<c:set var="nowdate31" value='<%=strDate31%>' /> 
Posted by 홍반장水 홍반장水
TAG Java, jsp, 날짜

댓글을 달아 주세요