콤마 찍기 (정규표현식)

Web/JavaScript 2021. 2. 22. 13:36 Posted by Request

//콤마찍기
function comma(str) {
    str = String(str);
    return str.replace(/(\d)(?=(?:\d{3})+(?!\d))/g, '$1,');
}

Permission denied: make_sock: could not bind to address [::]:80
Permission denied: make_sock: could not bind to address 0.0.0.0:80
no listening sockets available, shutting down
Unable to open logs

 

 

 

 

apache 데몬을 root 권한이 아닌 사용자 계정으로 실행 해서 나는 로그다.

 

기본적으로 예약된 포트는 root 권한 이외의 계정으로는 오픈 할 수 없다.

 

 

 

 

[출처] http://freeism.co.kr/tc/612

web server

Server/Unix/Linux 2017. 4. 27. 18:54 Posted by Request

출처 :

http://blog.naver.com/woony0622/150113410306

http://blog.naver.com/dudwo567890/130156854673

 

 

 

간만에 웹서버가 죽는 경우가 종종 있어 메모를 해놓는다.

 

 

 

프로세스 활성화 확인

 

ps -ef | grep httpd

 

 

웹 프로세스 모두 죽이기

 

killall -9 httpd

 

 

===============================

 

 

find . -name

 

 

 

 

웹서버 확인

./apachectl configtest

 

 

 

jquery 로 selectBox option 값 찾기

Web/JQuery 2016. 12. 30. 12:47 Posted by Request

jquery 로 selectBox option  값 중 값이 1인 걸 지우는게 가능 할까나?

 

출처 : http://mylife365.tistory.com/112

 

 

Text로 찾을 경우

$("select[name='test'] option:contains('테스트5')").attr("selected", "selected");

 

 

 

 

값으로 찾을 경우

$("select[name='test'] option[value='테스트3']").attr("selected", "selected");

[스크립 주소  ] http://smartjuho.tistory.com/entry/JQuery-%EC%99%80-Prototype-%EC%B6%A9%EB%8F%8C-%EB%B0%A9%EC%A7%80



JQuery와 prototype에서 $()를 사용하려면 충돌이 일어나 스크립트 오류를 일으킨다.

 

둘다 같은 $()를 쓰니까..

 

이를 해결하는 방법은 아래와 같다.

 

jQuery 와 prototype 을 정의한 아래줄에 다음의 소스를 추가한다.

 

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>

 

<script type="text/javascript">
jQuery.noConflict();
var j$ = jQuery;
</script>

 

위와 같이 정의해두면 jQuery에 대한 $()는 -> j$() 로 대체해서 사용할수 잇게된다.

 

물론 충돌도 일어나지 않는다.

 

++ 하지만! jquery의 다른 라이브러리를 다운로드 받아 사용하려면 해당 라이브러리의 $ 를 j$ 로 모두 바꿔줘야 하는 번거로움이 있다.

이는 스크립트를 가져오는 순서만 잘 나열해주면 바로 해결된다.

 

ex)

<script type="text/javascript" src"./js/jquery-1.6.2.min.js"></script> <!-- jquery 기본 라이브러리 -->
<script type="text/javascript" src="./js/jquery-ui-1.8.16.custom.min.js"></script> <!-- 별도로 다운로드 받은 라이브러리 -->

<script type="text/javascript">
jQuery.noConflict();
var j$ = jQuery;
</script>

<script type="text/javascript" src="./js/prototype.js"></script>

 

이런식으로 jquery를 먼저 로드하고 후에 prototype.js 를 로드하면 둘다 문제 없이 사용할 수 있다.


복사 대상이 되는 클래스는 java.lang.Cloneable 인터페이스를 반드시 구현(implements)해야 한다.

 

복사 대상이 되는 클래스가 직접 구현해도 상관없고, 상위 클래스 어딘가에서 구현해도 괜찮으며, Cloneable의 하위 인터페이스를 구현해도 상관없다.

 

Cloneable 인터페이스를 구현한 클래스의 인스턴스는 clone메소드를 호출하면 복사된다.

 

clone메소드를 사용하는 방법은

 

n         public Object clone()메서드의 재정의와 protected native Object clone메서드 사용

 

인데..

 

 

아래의 경우 super를 붙여준 이유는 super를 빼버리면 자기 자신이 가지고 있는

 

(즉, 오버라이드한 clone)을 호출하게 되므로 무한루프가 돌아서 stack over flow가 발생하게 된다.

 

따라서 아래와 같이 해주던지..super를 빼려고 한다면

 

createclone등으로 이름을 바꿔주고 호출하면 된다...

 

 

 

class SimpleClone implements Cloneable{       

             public int count=0;

             public SimpleClone(int count){

                           this.count = count;

             }           

             public Object clone(){                      

                           Object o = null;                  

                           try{                     

                                        o = super.clone();              

                           }catch (Exception e){System.out.println("can't clone object");}

                           return o; 

             }

}

public class LCopy{

             public static void main(String args[]){

                           SimpleClone sc1 = new SimpleClone(22);

                           SimpleClone sc2 = (SimpleClone)sc1.clone();

                           System.out.println("sc1 hashCode:"+sc1.hashCode() + ", count의값:" + sc1.count);

                           System.out.println("sc2 hashCode:"+sc2.hashCode() + ", count의값:" + sc2.count);

             }

}

 

%헷갈리지 말자%

보통 서적에 나와있는 clone을 사용하려면 그 클래스는 cloneable을 구현하고

clone메소드를 재정의 해줘야 한다고 나온다.

 

여기서 생각해보면 clone()메소드는 java.lang.Object의 메소드이고 Object 클래스는 모든 클래스의 상위 클래스인데 왜 굳이 clone()메소드를 오버라이드 해줘야 한다고 할까..?

 

즉, public TestClone implements Clonable{...}

라는 클래스가 있을때 그냥 clone이라고 사용을 해도 될텐데 왜 재정의가 필요하다고 할까?

 

clone이라는 것은 자기 자신을 복제하는 메소드이다. 보통 다른 클래스에서

 

복제를 요청하거나 위의 경우만해도 Main클래스에서 테스트를 위해 clone을 호출하고 있는데

 

이 clone메소드는 Protected형이다. 따라서 재정의가 없으면 이 메소드를 다른 패키지나 상속관계에 있지 않는 클래스들은 호출 할 수 없다는 것이다.

 

따라서..clone()메소드를

 

public Object clone(){

   return super.clone();

}

 

로 재정의 해주던가 아니면 아예 다른 이름으로

 

public Object runClone(){

  return clone(); //이 경우에는 super를 안 붙여도 됀다. 같은 이름의 메소드로 재정의 하지 않았기 때문에 자동적으로 상위 클래스에 있는 clone()메소드가 호출된다.

}

 

그래서 재정의를 해줘야 한다는 말이 나오는 것이다.

 

같은 이름으로 오버라이드를 해주던 다른 이름으로 다른 클래스에서 접근가능한 클래스를

만들어주던간에 어쨋든 구현을 해주어야 다른 클래스에서 접근이 가능하기 때문이다.

 

 

혹시 인터페이스를 구현했기 때문에 거기에

 

있는 추상메소드를 구현해야 한다고 생각하지 말자. Cloneable 인터페이스는 아무런 추상메소드도

 

가지고 있지 않다. 단지 이 인터페이스를 implements한 클래스는 clone을 사용하여 복사 가능하다

 

..라고 나타내 주는 것에 불과하다.

 

퍼옴 : http://devyongsik.tistory.com/60

 

JSTL 태그 - fn

Web/JSP 2016. 8. 9. 18:42 Posted by Request

fn:contains(string, sbustring) 

string이 substring을 포함하면 return True 


fn:containsIgnoreCase(string, sbustring) 

대소문자 관계없이 string이 substring을 포함하면 return True 


fn:endsWith(string, suffix) 

string이 suffix로 끝나면 return True 


fn:escapeXml(string) 

stting에 XML과 HTML에서 특별한 의미를 가진 문자들이 있으면,

XML엔티티 코드로 바꿔준뒤 문자열 반환 


fn:indexOf(string, sbustring)

 string에서 substring이 처음으로 나타나는 인덱스 반환 


fn:join(array, separator) 

array요소들을 separator를 구분자로 하여 연결해서 반환 


fn:length(item) 

item이 배열이나 컬렉션이면 요소의 객수를 문자열이면 문자의 객수를 반환 


fn:replace(string, before, after) 

string내에 있는 before 문자열을 after 문자열로 모두 변경해서 반환 


fn:split(string, separator) 

string내의 문자열 separetor에 따라 나누어서 배열로 구성해서 반환 


fn:startsWith(string, prefix) 

string이 prefix로 시작하면 return True 


fn:substring(string, begin, end) 

string에서 begin인덱스에서 시작해서 end인덱스에 끝나는 부분의 문자열 반환 


fn:substringAfter(string, sbustring) 

string에서 substring이 나타나는 이후의 문자열 반환 


fn:substringBefore(string, sbustring) 

string에서 substring이 나타나는 이전의 문자열 반환 


fn:toLowerCase(string) 

string을 모두 소문자로 바꿔 리턴 


fn:toUpperCase(string) 

string을 모두 대문자로 바꿔 리턴 

 

퍼옴 : http://thdnf1004.tistory.com/entry/JSTL-%ED%83%9C%EA%B7%B8-fn

jQuery serializeArray() 사용 예

Web/JQuery 2016. 8. 4. 10:11 Posted by Request

serializeArray()는

폼안에 입력요소의 값들을 object로 만들어 준다.

 

var fields = j$("#formID").serializeArray();

 

j$.ajax({

url : URL,

type : "POST"

data : fields,

success:function(data){

 

},

error:function(data){

}

});

[mysql]select for update for update transaction

DB/Mysql 2016. 7. 28. 18:38 Posted by Request

 

특정 row에 lock를 걸어서

다른 세션의 'select for update' 혹은 'select lock in share mode' 쿼리를 블락하고

싶은 경우 사용된다.

 

예)

select * from tableNm where column_name = '1' for update

 

 

출처 :

http://blog.daum.net/hazzling/17187062

 

 

 

 

 

 

 

서버 에러 로그

Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'or****': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.***.common.service.***] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@javax.annotation.Resource(shareable=true, lookup=, name=, description=, authenticationType=CONTAINER, type=class java.lang.Object, mappedName=)}

 

 

 

 

 

 

해결 방법

 

<context:component-scan base-package="egovframework,추가할패키지">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Service"/>
<context:include-filter type="annotation" expression="org.springframework.stereotype.Repository"/>
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>