(WinAPI) 디렉터리 제어 응용

IT/Programming/WinAPI 2014. 4. 21. 15:13

 

출처 : http://blog.daum.net/studiocoma/6521408

 

Win32 API가 제공하는 CreateDirectory 함수의 응용.

API CreateDirectory의 경우 c:\1\2\3을 만들때 c:\1\2가 이미 존재하지 않으면 실패한다. -_-

이를 보완하고(상위폴더부터 주구장창 만들어 낸다;) 경로에 파일명까지 포함되어 있어도 폴더만 만들도록 해봤다.
- 말은 거창(?)한데 그냥 문자열 파싱해서 CreateDirectory를 반복 호출한다;; 

BOOL _CreateDirectory( LPCTSTR lpszPath )
{
    TCHAR szPathBuffer[MAX_PATH];

    size_t len = _tcslen( lpszPath );

    for ( size_t i = 0 ; i < len ; i++ )
    {
        szPathBuffer[i] = *( lpszPath + i );
        if ( szPathBuffer[i] == _T('\\') || szPathBuffer[i] == _T('/') )
        {
            szPathBuffer[i + 1] = NULL;
            if ( ! PathFileExists( szPathBuffer ) )
            {
                if ( ! ::CreateDirectory( szPathBuffer, NULL ) )
                {
                    if ( GetLastError() != ERROR_ALREADY_EXISTS )
                        return FALSE;
                }
            }
        }
    }
    return TRUE;
}


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


CFileFind fileFinder;
 if(!fileFinder.FindFile(".\\simple\\MyMenu.mdb"))
 {
  CreateDirectory(".\\simple", NULL);
  CopyFile(".\\MyMenu.mdb", ".\\simple\\MyMenu.mdb", TRUE);
 }



부모디렉토리없어도 디렉토리 생성하기, 디렉토리에 파일있어도 하위디렉토리까지 모든파일 삭제하기


출처 :  http://www.devpia.com/MAEUL/Contents/Detail.aspx?BoardID=51&MAEULNo=20&no=7293&ref=7293

 

 

#include <windows.h>

#include <stdio.h>

#include <string>

 

using namespace std;

 

/*

 

  기존 디렉토리가 있을경우 안만들어지고 없으면 만든다. 부모디렉토리가 없어도 생성가능

 

*/

void CreateDir(char* Path)

{

    char DirName[256];  //생성할 디렉초리 이름

    char* p = Path;     //인자로 받은 디렉토리

    char* q = DirName;  

 

    while(*p)

    {

        if (('\\' == *p) || ('/' == *p))   //루트디렉토리 혹은 Sub디렉토리

        {

            if (':' != *(p-1))

            {

                CreateDirectory(DirName, NULL);

            }

        }

        *q++ = *p++;

        *q = '\0';

    }

    CreateDirectory(DirName, NULL);  

}

 

 

/*

 

 하위디렉토리를 제외한 해당 디렉토리 모든 파일들을 제거

 

 */

void DeleteAllFiles(char* folderPath)

{

    char fileFound[256];

    WIN32_FIND_DATA info;

    HANDLE hp;

 

    sprintf(fileFound, "%s\\*.*", folderPath);

    hp = FindFirstFile(fileFound, &info); //디렉토리에 파일이 있는지 첫번째 파일만.

    do

    {

        sprintf(fileFound,"%s\\%s", folderPath, info.cFileName);

        DeleteFile(fileFound);

 

    }while(FindNextFile(hp, &info));  //다른 파일이 있을때 까지

 

    FindClose(hp);

}

 

 

/*

 

 해당 하는 디렉토리에 파일이 존재해도  디렉토리가 비어있지 않아도 지울수 있다 .

 

*/

 

void EmptyDirectory(char* folderPath)

{

    char fileFound[256];

    WIN32_FIND_DATA info;

    HANDLE hp;

 

    sprintf(fileFound, "%s\\*.*", folderPath);

    hp = FindFirstFile(fileFound, &info);   //디렉토리에 파일이 있는지 첫번째 파일만.

    do

    {

        if (!((strcmp(info.cFileName, ".")==0)||(strcmp(info.cFileName, "..")==0)))

        {

            if((info.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)==FILE_ATTRIBUTE_DIRECTORY)  //Sub디렉토리가 존재하는경우

            {

                string subFolder = folderPath;

                subFolder.append("\\");

                subFolder.append(info.cFileName);

                EmptyDirectory((char*)subFolder.c_str()); /// {return (_Ptr == 0 ? _Nullstr() : _Ptr); }

                RemoveDirectory(subFolder.c_str());

            }

            else

            {

                sprintf(fileFound,"%s\\%s", folderPath, info.cFileName);

                BOOL retVal = DeleteFile(fileFound);

            }

        }

 

    }while(FindNextFile(hp, &info));

 

    FindClose(hp);

}


 

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


CreateDirectory 에서 폴더 접근 권한 바꾸기


출처 : http://ktr0.egloos.com/757379


Windows API 를 보면 CreateDirectory 라는 함수가 있다.

CreateDirectory("c:\aaa",NULL);

위와 같은 방법으로 첫번째 파라메터에 폴더 이름을 써 주고
두번째 파라메터에 NULL 을 써 주는 경우가 많다.

두 번째 파라메터는 사실 보안에 대한 파라메터이다.

PSECURITY_ATTRIBUTE 형의 변수가 들어가는데, NULL 이면 부모 폴더의
값을 그대로 가져온다.

 SECURITY_ATTRIBUTES sa;
 SECURITY_DESCRIPTOR sd;
 PSID pEveryoneSID = NULL;
 SID_IDENTIFIER_AUTHORITY SIDAuthWorld = SECURITY_WORLD_SID_AUTHORITY;
 EXPLICIT_ACCESS ea[2];
 PACL pacl = NULL;
 if(!AllocateAndInitializeSid(&SIDAuthWorld,1, SECURITY_WORLD_RID,0,0,0,0,0,0,0,&pEveryoneSID))
 {
  AfxMessageBox("Fail to get Everyone SID!!!",0,0);
  return;
 }
 ZeroMemory(&ea, 2*sizeof(EXPLICIT_ACCESS));
 ea[0].grfAccessPermissions = GENERIC_ALL;
 ea[0].grfAccessMode = SET_ACCESS;
 ea[0].grfInheritance = SUB_CONTAINERS_AND_OBJECTS_INHERIT;
 ea[0].Trustee.TrusteeForm = TRUSTEE_IS_SID;
 ea[0].Trustee.TrusteeType = TRUSTEE_IS_WELL_KNOWN_GROUP;
 ea[0].Trustee.ptstrName = (LPTSTR) pEveryoneSID;

 SetEntriesInAcl(1,ea, NULL, &pacl);
 InitializeSecurityDescriptor(&sd,SECURITY_DESCRIPTOR_REVISION);
 SetSecurityDescriptorDacl(&sd, TRUE,pacl , FALSE);
 //SetSecurityDescriptorSacl(&sd, TRUE,pacl , FALSE);


 sa.nLength = sizeof (SECURITY_ATTRIBUTES);
 sa.lpSecurityDescriptor = &sd;
 sa.bInheritHandle = TRUE;
 
 ::CreateDirectory(sysDirBuffer_tmp,&sa);
 if(pEveryoneSID){
  FreeSid(pEveryoneSID);
 }
 if(pacl){
  LocalFree(pacl);
 }

위의 예가 바로 CreateDirectory 함수에서 SECURITY_ATTRIBUTE 값을 가지고
폴더에 모든 ACCESS 권한을 주는 예제이다.

 

http://www.tipssoft.com/bulletin/board.php?bo_table=QnA&wr_id=380&page=392

GetCurrentDirectory 함수 : 현재의 작업 디렉토리를 얻어온다. 
SetCurrentDirectory 함수 : 작업디렉토리의 경로를 셋팅한다. 

일반적으로 작업디렉토리는 파일이 실행된 경로가 지정됩니다. 
아래는 작업디렉토리의 변경이 일어나는 대표적인 예인 CFileDialog 대화상자를 이용한 경우입니다 

참고하시면 될 듯 싶습니다. 


    char path[MAX_PATH] = {0}; 
    // 현재의 작업디렉토리를 저장한다. 
    GetCurrentDirectory(MAX_PATH, path); 

    // CFileDialog 를 Open 모드로 생성한다. 
    CFileDialog dlg(TRUE); 
    if(dlg.DoModal()==IDOK){ 
                // 사용자가 폴더를 옮겨가며 특정 파일을 지정 
                // 이경우 작업폴더가 변경됨. 
                CString str = dlg.GetFileName(); 
                //얻어온 파일과 관련된 코드 추가.............. 
                
                // 이전에 저장했던 작업디렉토리 경로를 되돌려 셋팅 
                SetCurrentDirectory(path); 
    }

 

 

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

 

Directory 컨트롤에 관하여 좋은 응용 예제를 모아놓은 블로그(http://blog.naver.com/dolicom/10096040743)에서 관련된 내용을 퍼왔다.

 

위의 응용 예제도 나쁘지 않지만, CreateDirectory 를 사용하여 디렉터리 트리를 구성할 때에는 CreateDirectory() 보다는 SHCreateDirectory / SHCreateDirectoryEx() 를 사용하는 것이 훨씬 편하다.

 

 SHCreateDirectoryEx(NULL, "C:\\a\\b\\", NULL);

 

이런식으로만 하면 a 폴더가 없더라도 a\b 폴더 둘 다 만들어지기 때문이다. 해당 함수를 쓰기 위해서는 Shlobj.h 를 포함시켜야 한다.

 

SHCreateDirectoryEx : http://msdn.microsoft.com/en-us/library/windows/desktop/bb762131(v=vs.85).aspx

 

SHSHFileOperation function : http://msdn.microsoft.com/en-us/library/windows/desktop/bb762164(v=vs.85).aspx

 

설정

트랙백

댓글

CentOS EPEL Repo 이용

IT/Programming/Solution/Tip 2014. 4. 16. 18:34

기본 패키지에서 설치할 수 없는 다양한 패키지들은 EPEL(Extra Packages for Enterprise Linux) 에서 구할수 있다.

 

CentOS EPEL Repo 를 설치해주고 원하는 패키지를 설치하면 된다.

 

아래는 weechat을 CentOS 5.4 에서 설치하는 예이다.

  1. Download the latest epel-release rpm from
    http://dl.fedoraproject.org/pub/epel/5/x86_64/
  2. Install epel-release rpm:
    # rpm -Uvh epel-release*rpm
  3. Install weechat-devel rpm package:
    # yum install weechat-devel
 

* 메신저로 추가 문의하는 사람이 있어 내용을 덧붙입니다.

여기서 EPEL 시리즈를 올바르게 설치하려면 위의 링크(http://dl.fedoraproject.org/pub/epel/5)에서 무작정 epel 을 내려 받지 마세요.

자신의 배포판 버젼과 시스템 아키텍쳐에 맞는 EPEL 을 설치하시길 바랍니다. 6.x 배포판을 x86_64 시스템 환경으로 구동하신다면

http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm 이 링크를 통해서 epel 을 설치할 수 있습니다.

 

epel rpm 은 올바르게 경로를 찾아가셔서 CTRL + F 로 epel 을 검색하셔서 rpm 주소를 가져오신 후, wget 등으로 rpm 을 내려받아 설치하시면 됩니다.

설정

트랙백

댓글

PHP 배열 활용 총망라

IT/Programming/Programming 2014. 4. 7. 20:13

(퍼온글) 출처 : http://www.picomax.net/xe/?mid=study&category=231&document_srl=557&sort_index=readed_count&order_type=desc&listStyle=viewer&page=54

 

======

 

php는 배열이 정말로 좋다... 신기하게도 모든 자료형과 객체들을 다 넣을 수 있다...

 

예전에 C를 배울때는 배열이 좋구나 라는 것을 느끼면서 하나씩 배우기는 시작했는데... C에서의 배열은 일단 틀(자료형과 개수)을 정해야한다는 단점이 있다.

그래서 여러가지 동적인 자료구조를 이용하지만 설정하는데 여러가지 번거로움이 존재한다.

자바에서는 그나마 배열이 동적으로 바뀌는 자료구조를 여러가지 채택하고 있지만... 연관배열 같은 구조는 바로 바로 쓰기 어렵다. 꼭 HashMap 이나 기타 다른 키값을 가지고 있는 클래스를 사용하여야 한다.

 

php는 스크립트 언어이다. 대부분의 스크립트 언어들이 유연한 자료구조로서 배열을 사용하는데 특히나 php는 따른 설정 없이 모든 자료형이 배열에 들어갈 수가 있다.

그래서 다른 언어에 있는 자료구조 형식을 따로 만들어 줄 필요가 없다... 그래서 php 하는 사람들이 자료구조에 약한가.. 흠.. ^^;;

 

  1. 모든 것을 담아라.

array 형은 모든 것을 담을 수 있다.

 

$arr = array(1, '안녕', 234.566, new Object(), array(1,2,3) );

 

여러가지 자료형을 동시에 담을 수 있다.

연관배열은 기본... $arr = array('aaa' => 'varchar'); 와 같은 방식으로 바로 바로 설정이 된다.

 

2. 특별한 자료 구조를 필요로 하지 않는다.

php에서는 배열은 동적으로 늘어나고 줄어들기 때문에 동적 자료구조를 만들 필요가 없다. 그리고 일반 자료구조처럼 조작할 수 있는 여러가지 함수들을 제공한다.

 

1) statck 형태로 사용하기

스택은 가장 나중에 들어간 데이타가 가장 먼저 나오는 구조이다. (LIFO)

pop, push 스택의 가장 기본적인 2가지 형태의 조작 방법이다.

pop은 가장 뒤에 있는 요소를 리턴해주고 배열에서 지워주는 것이고 push는 가장 뒤에 요소를 집어넣는다.

 

php는 array_pop($arr), array_push($arr, 데이타) 등으로 스택을 구현할 수 있다.

array_push 같은 경우는 언어 문법 상으로도 지원을 한다. $arr 이 배열일 경우 $arr[] = 데이타; 와 같은 형식은 array_push 와 같은 역할을 한다.

 

2 ) Queue 형태로 사용하기

Queue는 가장 먼저 들어간 데이타가 가장 먼저 나오는 구조 (FIFO) 이다.

그래서 큐는 기본적으로 push와 enqueue의 2가지 방법을 가진다. push는 데이타를 넣는 것이고 enqueue 는 젤 앞 요소를 리턴해주고 배열에서 삭제해준다.

 

php는 array_push($arr, 데이타), array_shift($arr) 등으로 구현한다.

 

3) Dequeue 형태로 사용하기

Dequeue 는 앞뒤 쪽으로 어느 곳으로 나 데이타를 빼고 넣을 수 있는 자료구조이다. stack과 queue를 잘 조합했다고 보시면 된다.

 

앞으로 넣을때는 array_unshift($arr, 데이타), 뒤로 넣을 때는 array_push($arr, 데이타)

앞에서 자료를 뺄 때는 array_shift($arr), 뒤로 자료를 뺄 때는 array_pop($arr)

4) 연결 리스트 (Linked List) 처럼 사용하기

연결 리스트라는 것은 배열의 단점을 보완하기 위해서 나온 것이다.

배열은 기본적으로 자료형과 크기가 정해져있다.

그래서 arr[100] 와 같이 100개의 요소를 가지는 배열을 선언해놓고 10개만 사용하면 메모리 사용측면에서 아주 안 좋게 된다.

이렇듯 메모리 사용을 좀 줄이고 유연한 배열 구조를 만들어 보고자 나온 것이 연결리스트이다. C에서는 포인터, java에서는 참조를 사용하지만

php에서는 애초에 동적으로 배열이 변하기 때문에 php의 배열 자체가 연결리스트와 비슷 하다고 보시면 된다.

 

연결리스트의 가장 좋은 점이 참조만으로 이루어진 자료형이라서 삽입과 삭제에 비용이 거의 들지 않는 다는 점이다.

php의 배열의 경우는 삭제는 쉽지만 중간에 삽입하는 것은 다른언어와 비슷한 절차를 가져야 한다.

삭제하는 방법은 unset($arr[10]) 과 같은 방법으로 요소를 메모리에서 지우면 된다.

 

5) Hash

Hash 라는 것은 고유키를 만들어서 그 키와 데이타를 일대일로 매칭 시키는 기법이다. 일반적으로 사전과 비슷하다고 보시면 된다.

php는 배열 자체적으로 연관배열이라고 하는 것을 지원한다.

 

$arr['key'] = 'value'; echo $arr['key'];

 

아주 간단하게 hash 구조로 셋팅이 가능하다. 배열이 자체적으로 지원을 하기 때문이다. 스크립트 언어들이 대부분 이런 구조를 지원하지만

vb 스크립트는 지원하지 않아서 asp 코딩할때 약간의 생각을 더 해야한다.

 

※ 기타 다른 구조들도 많지만 지금은 생각이 안나서 잠시 접어두도록 하겠다.

 

3. 배열 제어 방법

이제는 실제 php에서 배열을 제어 하는 방법을 알아보자..

 

1) Iterator 형식

php는 foreach라는 키워드를 이용해서 배열 요소를 바로 접근할 수 있게 해준다.

foreach ($arr as $value) { echo $value ; }

 

키값을 가지고 있는 배열도 바로 사용 할 수 있다. 어떻게? ㅋ 바로 이렇게

foreach ($arr as $key => $value) { echo $key, $value; }

 

php5 들어오면서 재미난 기능이 하나 더 생겼다. php4에서는 foreach에서 나오는 배열 값을 실제 배열 요소로서 조작이 불가능했다. 하지만 php5에서는 가능하다.

foreach ($ass as &$value) { $value = $value.'aaa'; }

 

값을 참조 형태로 받을 수 있기 때문에 그 배열 요소에 있는 값들을 바로 수정하는 것도 가능하다. 재밌는 기능이다.

 

2) list, each 함수를 사용하기

list 함수는 배열을 각각의 변수로 바꿔주는 것이고 each는 배열에서 키와 값을 배열 형태로 넘겨주는 함수이다. 예를 들어서

$arr = array(0 => 1, 1=> 2, 2 => 3);

while(list($key, $value) = each($arr)) {

echo $key, $value;

}

 

대충 이런 형태로 가능한데. 요즘은 이렇게 쓰는 사람이 잘 없다. foreach가 더 심플하니깐.. .

 

3) 연관 배열은 key, value로 이루어져 있으니 그냥 셋팅만 해주면 된다.

$arr = array( 'key' => 'value' ); 형태로 셋팅하면 끝.. 사용할 때는 $arr['key'] 로 얻어오면 됨..

 

4. 배열을 위한 유틸리티 함수들

php의 동적 배열을 좀 더 자유롭고 유연하게 이용할 수 있도록 여러가지 함수들을 지원한다.

 

1) 키 또는 값으로만 배열 만들기

$keys = array_keys($arr);

$values = array_values($arr);

 

2) 배열 값을 유니크한 배열로 만들기

$unique = array_unique($arr); // 만약 값이 array(1, "1", 2, 3,"3") 이런식이라면 만들어 지는 배열은 array(1,2,3) 이 됩니다.

 

3) 배열 값으로 합계내기

$sum = array_sum($arr);

 

4) 배열 요소에 모두 특정 함수 사용하여 변환하기

보통 배열을 특정 함수를 이용해서 바꿀려고 하면 loop를 도는게 일반적인 방식이다.

for ($i = 0; $i < 10; $i++) {

$arr[$i] = strtoupper($arr[$i]);

}

 

하지만 php에서는 이런상황을 위해서 여러가지를 지원하는데 가장 간단한 구조가 array_map 이다. array_map은 주어진 함수를 가지고 변환한 값들을 새로운 배열로 만들어 낸다. 위의 제어 구분을 아주 간단하게 바꾸면 아래와 같다.

 

$arr = array_map('strtoupper', $arr); // 모든 요소 대문자로 변경

$arr = array_map('trim', $arr); // 모든 요소 공백 제거

 

여기서 앞에 사용되어지는 함수 이름은 문자열로 들어간다. 함수는 매개변수를 하나만 가진다.

 

5) 배열 2개로 연관 배열 만들기

$keys = array('1','2','3','4');

$values = array('a','b','c','d');

 

$arr = array_combine($keys, $values) ; 하면

$arr = array('1' => 'a' , '2' => 'b', '3' => 'c', '4' => 'd'); 와 같은 형태로 변경이 된다.

 

6) 배열에 값이 있는지 없는지 체크하기

단순하게 체크 할 때는 in_array 라는 함수를 사용한다.

$arr = array(1, 2, 3, 4, 5,);

if (in_array(1,$arr)) { echo "1 포함"; }

 

아주 쉽다. 그렇다면 배열에 배열이 들어가 있는 이중배열은 어떻게 될까?

$arr = array(array(1, 2,), 3, 4, 5, array(6, 7));

if (in_array(array(1,2), $arr)) { echo "array(1, 2) 가 있음 "; }

 

배열 자체적으로 체크도 가능하다.

 

7) 자료형이 배열인지 알아볼려면 ?

echo is_array($arr) ;

 

8) 배열을 정렬 할려면..

(1) 값을 기반으로 정렬 : sort($arr); , 역순 정렬 : rsort($arr);

(2) 키를 기반으로 정렬 : ksort($arr); , 역순 정렬 : krsort($arr);

(3) 사용자 정의 함수로 정렬하기 : usort($arr, callback);

function cmp($a, $b) {

if ($a == $b) return 0;

return ($a < $b) ? -1 : 1 ;

}

usort($arr, "cmp"); 하면 자동으로 사용자 정의 함수를 기반으로 바뀐다.

 

같으면 : 0, 작으면 : -1, 크면 : 1 로 함수로 잘 만들어보삼.. 당신의 능력을 믿어요.. ^^/

 

일단은 이정도.... 다르게 정렬 하는 함수들이 있지만 다음에 소개할게요...

 

9) 서브 배열 가지고 오기

가끔 배열도 중간에 있는 리스트만 가지고 오고 싶을 때가 있다... 파이썬의 경우는 배열 자료형 자체도 객체이기 때문에 arr[:10] 과 같은 슬라이스 형태로

서브배열을 가지고 오는 것이 가능하지만 php는 아직 그런것은 안되고 함수로 지원을 한다.

$arr = array(1, 2, 3, 4, 5);

$sub = array_slice ($arr, 2); // array(3, 4, 5);

$sub = array_slice($arr, 2, 1); // array(3);

$sub = array_slice($arr ,2, -1); // array(3, 4);

 

위와 같은 형태로 배열을 가지고 올 수 있습니다.

기본 형태는 array_slice (배열, 시작지점, 길이); 정도로 된다. 길이는 생략가능하고 길이가 안정해지면 마지막 요소까지로 측정된다.

 

10) 배열 요소 랜덤으로 가지고 오기

$values = array_rand($arr, $num);

 

위와 같은 형태로 사용하는데... 내부적으로 rand() 함수를 부르기 때문에 srand() 를 미리 실행해야 정확하게 각 시간별 랜덤결과를 얻을 수 있다.

srand(time());

$pick = array_rand($arr, $num);

 

$num 은 랜덤으로 가지올 개수인데 1 개 일때는 그냥 일반 자료형으로 리턴해주고 2개 이상일때는 해당 키값들을 배열로 리턴해준다.

그래서 실제 사용할려면

echo $arr[$pick[0]]; 형태로 값을 출력시켜야한다.

 

11) 배열 합치기 (합집합)

$new_arr = array_merge($ar1, $ar2); 와 같은형태로 배열을 합칠 수 있다.

연관 배열로 이루어진 배열들은 키값이 같으면 뒤에서 합쳐진 배열 값을 기준으로 값이 정해진다.

여기서 재미난 거 하나 .

$ar1 = array();

$ar2 = array(1 => 'a');

$new = array_merge($ar1, $ar2) ; // array(0 => 'a') 와 같은 형태로 기존의 인덱스는 완전 무시 된다. 이것을 방지할려면 + 연산자를 이용할 수 있다.

 

$new = $ar1 + $ar2; // array(1 => 'a'); 배열끼리 + 연산자를 사용하면 인덱스를 유지한채 배열을 합칠 수 있다. ㅋ

 

12) 키 값 존재 여부

if (array_key_exists('key', $arr)) { echo 'key 값 확인'; }

 

13) 교집합 구하기

교집합은 값을 기준으로 구할 수 있다.

$arr1 = array('a' => '안녕', '바보', '메롱');

$arr2 = array('b' => '안녕', '메롱', '쪼다');

$result = array_intersect($arr1, $arr2); // array('a' => '안녕', 0 => '메롱');

 

14) 키와 값의 위치 바꾸기 (키 <-> 값)

$arr = array('a' => 1, 'b' => 1, 'c' => 2);

$temp = array_flip($arr); // array(1 => 'b', 2 => 'c');

 

15) 요소 개수별로 서브 배열 만들기

$arr = array(1, 2, 3, 4, 5);

$temp = array_chunk($arr, 2); // array(array(1,2), array(3, 4), array(5));

$temp = array_chunk($arr, 2, true); // array(array(0 => 1, 1 => 2), array(2 = >3, 3 => 4), array(4 => 5));

설정

트랙백

댓글

/etc/lightdm/lightdm.conf 수정 후 부팅 문제

IT/Programming/Solution/Tip 2014. 4. 5. 22:52

Ubuntu에서 root 로그인을 위해 /etc/lightdm/lightdm.conf 에서 greeter-show-manual-login=true 설정을 적용했을 때 부팅이 안되는 경우, recovery 모드나 싱글 모드나 live cd 등을 이용하여 쉘을 띄운 후 다음과 같이 작업한다. :

 

/etc/lightdm/lightdm.conf.d/50-unity-greeter.conf 를 열고 아래와 같이 해당 내용을 편집한다 :

 

[SeatDefaults]
 greeter-session=unity-greeter
 greeter-show-manual-login=true

 

필자가 직접 경험한 문제는 아니고, 친구 문제의 해결을 도우면서 겪은 이슈라서 바로 해결되지 않을 수 있다.

 

그래도 문제가 계속 일어난다면, /etc/lightdm/lightdm.conf 에 적용된 greeter-show-manual-login=true 설정을 해제해주면 된다.

설정

트랙백

댓글

The Expert (Short Comedy Sketch)

ETC/Whatever! 2014. 4. 5. 17:40

'ETC > Whatever!' 카테고리의 다른 글

SNS 세상에서 늙어간다는 것.. Getting Old..  (0) 2010.11.14
cisco 안마기?!  (1) 2010.09.27
쉘노트 - shellnote  (0) 2010.09.27
You are being Monitored!  (0) 2010.06.29
Art : Wiltshire's CD Sea  (0) 2010.06.25

설정

트랙백

댓글