전자정부프레임워크에 회원가입도 했고

통합개발환경도 압축을 풀고 Eclipse를 실행하는데


1. Failed to load the JNI shared library "C:\Java\jre6\bin\client\jvm.dll"


이것은 64bit를 설치하려는데 설치된 JAVA가 32bit일 수 있다.

다시 32bit로 받아서 실행해야한다.



2. 설명서대로 처음프로젝트를 생성했는데

src 폴더와 target 폴더만 생성되고 아무것도 없을 때,

설정된 JVM이 8일 수 있다.


eclipse 실행시 JDK1.8 대신 JDK6 이나 7로 바꾸고 프로젝트를 생성해본다.

댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

전자정부 프레임워크에서 달력구현방법.


결론 : HTML5에서 input type에 date를 넣으면 된다면서 API에서 빼버림. 쩝.


HTML5로 구현


<label for="yyyyMmDd">날짜 :</label>
<input type="date" name="yyyyMmDd" id="yyyyMmDd" value="" />


오늘날짜 기본값으로 주기

               $(document).ready(function() {
                   var date = new Date();
   
                   var day = date.getDate();
                   var month = date.getMonth() + 1;
                   var year = date.getFullYear();
   
                   if (month < 10) month = "0" + month;
                   if (day < 10) day = "0" + day;
   
                   var today = year + "-" + month + "-" + day;      
                   $("#yyyyMmDd").attr("value", today);
               });

댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

Android cannot connect directly to the database server. Therefore we need to create a simple web service that will pass the requests to the database and will return the response.


--------------------------------------------------------------------------------

불편하게 왜 웹서버를 통해서 DB에 접근하나 싶어

DB접속모듈을 만들어서 바로 호출하려고 해 보니...


12-17 11:17:35.221: I/dalvikvm(2543): Could not find method javax.naming.Reference.get, referenced from method com.mysql.jdbc.ConnectionPropertiesImpl$ConnectionProperty.initializeFrom


등의 에러가 난다.. 쩝.


그래서 찾아보니 위와 같은 문구가 2012년도 게시글에 나온다...

"안드로이드는 DB서버에 직접접근이 안된다. 그래서 요청을 DB에 하고 응답을 받을 수 있는 간단한 웹서비스를 만들 필요가 있다" 라고 하네... 쩝.


출처 : http://stackoverflow.com/questions/12233145/connecting-to-mysql-from-android-with-jdbc



댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

   

원문 : http://huammmm1.tistory.com/373


당췌 API쓰기가 왜이렇게 어려운 건지...

카톡을 사용하려면 앱키와 키해시가 있다.


앱키는 앱을 추가할 때 카톡API에서 생성되는것이고

키해시는 실제 소스에서 APK생성시에 만들어진다.


카톡 API에서 키해시등록을 하는 방법이 귀찮게 되어있는데

샘플App의 시작Activity에서 아래 method를 호출하면 로그캣에 찍힌다.


KakaoTalkLoginActivity에서

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setBackground(getResources().getDrawable(R.drawable.kakaotalk_sample_login_background));
        Log.d("KakaoTalkLoginActivity", "onCreate ");
        getAppKeyHash();// 호출
    }


//////// method 추가

private void getAppKeyHash() {
        try {
            PackageInfo info = getPackageManager().getPackageInfo(getPackageName(), PackageManager.GET_SIGNATURES);
            for (Signature signature : info.signatures) {
                MessageDigest md;
                md = MessageDigest.getInstance("SHA");
                md.update(signature.toByteArray());
                String something = new String(Base64.encode(md.digest(), 0));
                Log.d("Hash key", something);
            }
        } catch (Exception e) {
            // TODO Auto-generated catch block
            Log.e("name not found", e.toString());
        }
    }

댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

몇 달전 카톡 API를 써보려 했을 때

그때는 친구목록이 나타나지 않았었다.

'이게 뭐야? 친구목록 없으면 어떻게 해?' 하며 진행을 하지 않았다.

이제는 친구목록이 나온댄다.


그래서 해 보려는데....

Eclipse에서 하려니 자꾸 뭔가 충돌이 난다.

구글에서도 gradle로 갈 예정이라고 하고 찾아보니 gradle 예제가 있길래 따라하기 위해 설치했다.


그런데... 카톡 키해시를 받기가 쉽지가 않구만...


카톡에서는

keytool -exportcert -alias <release_key_alias> -keystore <release_keystore_path> | openssl sha1 -binary | openssl base64
이렇게 치라고 했는데

안되는게
java classpath가 안잡혀있어서 직접
cd
c:\Java\jdk1.7.0_71\bin 으로 이동

그리고 openssl도 설치가 안되어 있어서 직접 다운(http://slproweb.com/products/Win32OpenSSL.html)받아 설치한 다음



c:\Java\jdk1.7.0_71\bin>keytool -exportcert -alias 키스토어명 -keystore 키스토어저장경로 | C:\OpenSSL-Win32\bin\openssl sha1 -binary | C:\
OpenSSL-Win32\bin\openssl base64


이렇게 하니까 키해시는 만들어졌다.

댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

2011년 만든 염주 앱

업그레이드를 하려고 했더니... 키스토어 파일이 없네

그래서 새로 염주앱을 만들었는데 별로 이용하지 않네 ㅎ

확 내릴까 하고 생각하고 기념으로 캡쳐를 하다보니


처음 염주 만들 때의 생각

'염주는 세는기능만 있으면 되는거 아냐?'라고

누군가는 많은 기능 필요없이 그저 세는 기능만 필요할 수도 있겠다 싶어서 놔두기로 함.


여러가지 기능을 추가한 새로운 앱은

https://play.google.com/store/apps/details?id=com.nobang.rosary2free

요기에서 받아 사용하시길








댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

자꾸 android content loader 0 와 함께 응답이 없어 구글로 많은 내용을 찾아본 결과 가장 확실한 것 같다. ㅎ



방법1: 커맨드 창에서 eclipse 폴더로 간 다음 "eclipse -clean"을 실행시킨다.

(start eclipse from command line"
run eclipse -clean
)


방법2: workspace 폴더로 간 다음 아래 경로로 가서 모든 프로젝트 정보를 지운다

\workspace\.metadata\.plugins\org.eclipse.core.resources\.projects
(

Go to your workspace directory \workspace\.metadata\.plugins\org.eclipse.core.resources\.projects and delete all the projects in there.
)


방법3: 
1. eclipse가 확실이 종료되었는지 확인한다. 작업관리자에 eclipse 항목이 있으면 kill 시킨다.

2. 사용자 폴더로 간다. (window의 경우 로그인한 사용자 경로를 찾는다)

3. .android 폴더로 간다.(숨겨진 폴더일 수 있다.)

4. cache 폴더안의 내용을 모두 지운다.

5. ddms.cfg 파일을 지운다.

6. eclipse를 

  1. Make sure that eclipse is not active. If it is active kill eclipse from the processes tab of the task manager
  2. Open %USERPROFILE%/ (You can locate this folder from desktop)
  3. Go to .android folder (This may be a hidden folder)
  4. Delete the folder "cache" which is located inside .android folder
  5. Delete the file ddms.cfg which is located inside .android folder
  6. Start eclipse
(나의 경우에는 3까지 하니까 성공했다)

방법4:
1. 아래 폴더를 삭제한다.
/workspace/.metadata/.plugins/org.eclipse.e4.workbench/workbench.xmi
(
Delete:
/workspace/.metadata/.plugins/org.eclipse.e4.workbench/workbench.xmi

)


원본 : http://kaparkx.blogspot.kr/2014/04/eclipse-hangs-at-android-sdk-content.html

댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

sqlite에 Excel 파일 등을 import 할 때 문제는 csv에서 한글이 깨진다는 것이다.

운좋게 csv까지 한글이 깨지지 않더라도 sqlite에 다시 넣을 때에는 깨질 수 있다.

그런데... 가장 편한 방법은 파이어 폭스를 이용하는 것이다.

1. 파이어 폭스를 다운받는다.

2. 파이어 폭스를 실행한 뒤 추가기능에서 sqlite를 검색한다

"Sqlite Manager"를 설치한 뒤 실행한다.

CSV파일을 임포트하면 한글까지 완전히 sqlite로 떨어진다 호호홋.

댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절


PhoneGap에서 SQLITE를 사용하기 위한 설정이다. 구조는 이미지와 같으며

다음 순서로 기본 세팅을 한다.

1. AndroidManifest.xml
   : 권한 추가. 
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

--전체

<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

    package="com.nobang.phonegapsql"

    android:versionCode="1"

    android:versionName="1.0" >


    <uses-sdk

        android:minSdkVersion="16"

        android:targetSdkVersion="19" />


    <application

        android:allowBackup="true"

        android:icon="@drawable/ic_launcher"

        android:label="@string/app_name"

        android:theme="@style/AppTheme" >

        <activity

            android:name="com.nobang.phonegapsql.MainActivity"

            android:label="@string/app_name" >

            <intent-filter>

                <action android:name="android.intent.action.MAIN" />


                <category android:name="android.intent.category.LAUNCHER" />

            </intent-filter>

        </activity>

    </application>

    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />   

</manifest>

2. /res/xml/config.xml
 : 폰갭 라이브러리 세팅을 하면 config.xml을 해당 위치에 복사하게 되는데 sqlite를 사용하려면 이것에 플러그인 설정을 추가해야한다. <plugins></plugins> 사이에 네가지를 추가한다.

<?xml version="1.0" encoding="UTF-8"?>

<widget xmlns     = "http://www.w3.org/ns/widgets"

        id        = "io.cordova.helloCordova"

        version   = "2.0.0">

<plugins>

        <plugin name="SQLitePlugin" value="org.pgsqlite.SQLitePlugin"/>

      <plugin name="App" value="org.apache.cordova.App"/>

      <plugin name="Geolocation" value="org.apache.cordova.GeoBroker"/>

      <plugin name="Device" value="org.apache.cordova.Device"/>

    </plugins>

</widget>

3. /src/org.pgsqlite/SQLitePlugin.java
   해당 파일을 그래도 사용한다. 내 프로젝트에서 사용하기때문에 패키지명을 바꿨더니 javascript에서 에러남.

4. /assets/www/js 아래에 cordova.js 와 SQLitePlugin.js 를 넣는다

5. index.html을 작성한다

  cordova.js와 SQLitePlugin.js를 import하고 
  문서가 onLoad될 때, db 및 table 생성, 조회를 한문장으로 처리

(필요시 각각 기능을 나누면 됨 )


<!DOCTYPE html>

<html>

  <head>

  <title>Lawnchair Spec</title>

  

    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no;" />

<meta charset="utf-8">


<script type="text/javascript" charset="utf-8" src="js/cordova.js"></script>

    <script type="text/javascript" charset="utf-8" src="js/SQLitePlugin.js"></script>

    

    <script type="text/javascript">

document.addEventListener("deviceready", onDeviceReady, false);


var db;

    function onDeviceReady() {

    // open database

db = window.sqlitePlugin.openDatabase({name: "MyDB"});

// create table;

db.transaction(function(tx) {

tx.executeSql('CREATE TABLE IF NOT EXISTS test_table (id integer primary key, data text, data_num integer)');

});

// insert data

db.transaction(function(tx) {

     tx.executeSql("INSERT INTO test_table (data, data_num) VALUES (?,?)", ["test", 100], function(tx, res) {

         console.log("insertId: " + res.insertId + " -- probably 1");

         console.log("rowsAffected: " + res.rowsAffected + " -- should be 1");

       });

});

// select data

db.transaction(function(tx) {

            tx.executeSql("select count(id) as cnt from test_table;", [], function(tx, res) {

              console.log("res.rows.length: " + res.rows.length + " -- should be 1");

              console.log("res.rows.item(0).cnt: " + res.rows.item(0).cnt + " -- should be 1");

            });

});

}

    

    </script>

  </head>

  <body>

  </body>

</html>



댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

http://blog.daum.net/janustop/169

위 블로그에 내용을 하나씩 따라 해 본다.

JSP 페이지에 캐릭터 셋

스프링에 인코딩 캐릭터 셋

Maven 설정 등

그래도 나의 경우에는 안됐다. ㅜㅜ

(대부분의 경우에는 될꺼다 )

아마 Mysql의 인코딩 설정때문일 수도 있다.

결국 

http://jmnote.com/wiki/MySQL_%EC%BA%90%EB%A6%AD%ED%84%B0%EC%85%8B_utf8_%EC%84%A4%EC%A0%95

이곳의 설정대로 mysql의 인코딩 세팅을 했더니 된다 ㅎㅎ


sudo vi /etc/my.cnf 를 수정한 다음

show variables like 'char%'

해보니 모두 utf-8로 바뀌어있다 ㅋㅋㅋ

참고로 blob 형태의 칼럼을 가져올 때

, CAST(( CONTENTS) AS CHAR(10000) CHARACTER SET UTF8) AS CONTENTS

로 해서 가져왔다.

댓글을 달아주세요:: 네티켓은 기본, 스팸은 사절

BLOG main image
"그게 뭐 어쨌다는 거냐?" 늘 누가 나에게 나에대한 말을할 때면 이말을 기억해라. by nobang

카테고리

nobang이야기 (1606)
Life With Gopro (7)
Life With Mini (72)
Diary (910)
너 그거 아니(do you know) (119)
난 그래 (119)
속지말자 (9)
Project (34)
Poem (14)
Song (0)
Study (125)
Photo (113)
낙서장 (45)
일정 (0)
C.A.P.i (2)
PodCast (0)
nobang (27)
고한친구들 (4)
recieve (0)
History (0)
android_app (2)

최근에 받은 트랙백

Total : 489,089
Today : 103 Yesterday : 260