KR20230124206A - Document management service server for managing document files based on location information, and the operating method thereof - Google Patents
Document management service server for managing document files based on location information, and the operating method thereof Download PDFInfo
- Publication number
- KR20230124206A KR20230124206A KR1020220021220A KR20220021220A KR20230124206A KR 20230124206 A KR20230124206 A KR 20230124206A KR 1020220021220 A KR1020220021220 A KR 1020220021220A KR 20220021220 A KR20220021220 A KR 20220021220A KR 20230124206 A KR20230124206 A KR 20230124206A
- Authority
- KR
- South Korea
- Prior art keywords
- location information
- document file
- document
- user terminal
- polynomial
- Prior art date
Links
- 238000011017 operating method Methods 0.000 title abstract description 7
- 230000005540 biological transmission Effects 0.000 claims description 38
- 230000006870 function Effects 0.000 claims description 38
- 238000000926 separation method Methods 0.000 claims description 23
- 238000000034 method Methods 0.000 claims description 17
- 238000000605 extraction Methods 0.000 claims description 9
- 239000000284 extract Substances 0.000 claims description 7
- 238000012545 processing Methods 0.000 claims description 7
- 238000004590 computer program Methods 0.000 claims description 5
- 238000012795 verification Methods 0.000 description 11
- 238000010586 diagram Methods 0.000 description 4
- 238000012423 maintenance Methods 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 238000012790 confirmation Methods 0.000 description 1
- 230000002708 enhancing effect Effects 0.000 description 1
- 230000005226 mechanical processes and functions Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/06—Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/907—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
- G06F16/909—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually using geographical or spatial information, e.g. location
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/93—Document management systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/60—Methods or arrangements for performing computations using a digital non-denominational number representation, i.e. number representation without radix; Computing devices using combinations of denominational and non-denominational quantity representations, e.g. using difunction pulse trains, STEELE computers, phase computers
- G06F7/72—Methods or arrangements for performing computations using a digital non-denominational number representation, i.e. number representation without radix; Computing devices using combinations of denominational and non-denominational quantity representations, e.g. using difunction pulse trains, STEELE computers, phase computers using residue arithmetic
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L61/00—Network arrangements, protocols or services for addressing or naming
- H04L61/50—Address allocation
- H04L61/5007—Internet protocol [IP] addresses
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/04—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
- H04L63/0428—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/10—Network architectures or network communication protocols for network security for controlling access to devices or network resources
- H04L63/108—Network architectures or network communication protocols for network security for controlling access to devices or network resources when the policy decisions are valid for a limited amount of time
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/52—Network services specially adapted for the location of the user terminal
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0861—Generation of secret information including derivation or calculation of cryptographic keys or passwords
- H04L9/0869—Generation of secret information including derivation or calculation of cryptographic keys or passwords involving random numbers or seeds
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Databases & Information Systems (AREA)
- Computing Systems (AREA)
- Computer Hardware Design (AREA)
- Data Mining & Analysis (AREA)
- Computational Mathematics (AREA)
- Mathematical Analysis (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- General Business, Economics & Management (AREA)
- Mathematical Physics (AREA)
- Library & Information Science (AREA)
- Business, Economics & Management (AREA)
- Health & Medical Sciences (AREA)
- Bioethics (AREA)
- General Health & Medical Sciences (AREA)
- Software Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Storage Device Security (AREA)
Abstract
Description
본 발명은 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버 및 그 동작 방법에 대한 것이다.The present invention relates to a document management service server for managing document files based on location information and an operation method thereof.
최근, 기업이나 공공기관 등에서 전자 문서를 활용한 업무가 증가함에 따라, 전자 문서를 활용하는 사용자의 편의성을 증대시키기 위한 다양한 서비스들이 등장하고 있다.BACKGROUND ART [0002] Recently, as the number of businesses using electronic documents increases in corporations and public institutions, various services for enhancing user convenience using electronic documents have emerged.
한편, 이러한 다양한 전자 문서 관련 서비스들 중에서, 복수의 문서 파일들을 데이터베이스에 저장하여 관리하기 위한 문서 관리 서비스에서는, 데이터베이스에 저장되어 있는 복수의 문서 파일들 중 사용자가 자신이 원하는 문서 파일을 검색할 수 있도록 지원하는 문서 파일 검색 기능을 지원하는 경우가 많다.Meanwhile, among these various electronic document related services, in a document management service for storing and managing a plurality of document files in a database, a user can search for a desired document file among a plurality of document files stored in a database. In many cases, it supports a document file search function that supports
이와 관련해서, 기존의 문서 관리 서비스에서는 일반적으로, 사용자가 입력한 검색어를 기반으로 문서 파일을 검색할 수 있도록 하는 문서 파일 검색 기능을 제공하는 경우가 많은데, 이러한 문서 관리 서비스에서, 데이터베이스 상에 문서 파일들과 각 문서 파일이 생성된 지점의 위치 정보를 매칭시켜 저장해 둠으로써, 사용자가 현재 위치하고 있는 지점의 위치 정보를 기초로 해당 위치 정보에 근접한 지점의 위치 정보를 갖는 문서 파일을 검색할 수 있도록 하는 문서 파일 검색 기능을 제공할 수 있다면, 사용자의 편의를 보다 증대시킬 수 있을 것이다.In this regard, existing document management services generally provide a document file search function that allows a user to search for a document file based on a search word entered. In such a document management service, a document on a database By matching and storing files and the location information of the point where each document file was created, the user can search for a document file having location information of a point close to the location information based on the location information of the point where the user is currently located. If it is possible to provide a document file search function to search for documents, it will be possible to further increase user convenience.
아울러, 기업이나 공공기관에서 생산된 전자 문서들은 외부에서는 접근이 금지된 보안 문서인 경우가 많은데, 이러한 전자 문서들에 대해서는 각 전자 문서가 생성된 지점의 위치에 근접한 지점에서만 해당 전자 문서에 접근이 가능하도록 할 필요가 있다는 점에서, 사용자가 위치 정보를 기반으로 자신이 접근 가능한 문서 파일들을 검색할 수 있도록 하고, 해당 문서 파일을 제공받을 수 있도록 하는 문서 관리 서비스의 도입이 필요하다.In addition, electronic documents produced by corporations or public institutions are often security documents that are prohibited from being accessed from the outside. Access to these electronic documents is limited to points close to the location where each electronic document was created. In view of the need to make it possible, it is necessary to introduce a document management service that allows users to search for document files accessible to them based on location information and to receive the document files.
이와 관련해서, 데이터베이스에 문서 파일들을 저장할 때, 각 문서 파일이 생성된 지점에 대한 위치 정보를, 문서 파일과 대응시켜 함께 저장해 둠으로써, 위치 정보를 기반으로 문서 파일을 관리할 수 있는 기술의 도입을 고려할 수 있다.In this regard, when storing document files in a database, location information on the point where each document file was created is stored together in correspondence with the document file, thereby introducing a technology capable of managing document files based on location information can be considered.
즉, 사용자들이 전자 문서를 작성함에 따라, 새로운 문서 파일들이 생성되면, 각 문서 파일이 생성된 지점의 위치 정보와 각 문서 파일을 문서 파일 데이터베이스에 함께 대응시켜 저장해 둠으로써, 추후 다른 사용자로부터 자신이 현재 위치하고 있는 지점에서 접근 가능한 문서 파일에 대한 검색 요청이 수신되는 경우, 상기 문서 파일 데이터베이스로부터 해당 사용자의 위치와 근접한 위치 정보를 갖는 문서 파일들만을 검색하여, 이에 대한 검색 결과를 사용자에게 제공한 후, 사용자로부터 상기 검색 결과에 포함된 문서 파일들 중 특정 문서 파일에 대한 제공 요청이 수신되면, 이에 대한 문서 파일을 사용자에게 제공할 수 있는 문서 관리 서비스의 도입을 고려할 수 있다.That is, when new document files are created as users create electronic documents, location information of the point where each document file is created and each document file are stored in a document file database in correspondence with each other, so that they can be easily identified by other users later. When a search request for document files accessible from the current location is received, only document files having location information close to the user's location are searched from the document file database, and search results are provided to the user. , When a request for provision of a specific document file among the document files included in the search result is received from the user, introduction of a document management service capable of providing the user with the corresponding document file may be considered.
이러한 위치 기반의 문서 관리 서비스가 도입된다면, 각 문서 파일이 생성된 지점에서 벗어난 다른 지점에서는 해당 문서 파일에 대한 접근이 불가능하기 때문에, 외부의 제3자에 의한 문서 파일의 후킹(hooking) 등의 보안 문제를 해소할 수 있다.If such a location-based document management service is introduced, since access to the document file is not possible at a point other than the point where each document file was created, hooking of the document file by an external third party Security problems can be solved.
본 발명은 문서 파일이 생성된 지점의 위치와 근접한 위치에서만 해당 문서 파일에 접근할 수 있도록 하는 문서 관리 서비스 서버 및 그 동작 방법을 제시함으로써, 문서 파일이 생성된 지점이 아닌 외부의 다른 지점에 위치하고 있는 제3자에 의한 문서 파일의 노출 문제를 해소할 수 있도록 한다.The present invention provides a document management service server and its operation method that allow access to a document file only from a location close to the location where the document file is created, and is located at a point other than the point where the document file is created. It helps to solve the problem of exposure of document files by third parties.
본 발명의 일실시예에 따른 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버는 복수의 문서 파일들과, 상기 복수의 문서 파일들 각각이 생성된 지점의 위치 정보가 서로 대응되어 저장되어 있는 문서 파일 데이터베이스, 제1 사용자 단말로부터, 위치 정보 기반의 문서 파일 검색 요청이 수신되면, 상기 제1 사용자 단말로, 상기 제1 사용자 단말의 현재 위치 정보의 전송을 요청하는 제1 위치 정보 요청부, 상기 제1 사용자 단말로부터 제1 위치 정보가 수신되면, 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 사전 설정된 기준 반경 이내의 위치 정보를 갖는 문서 파일이 존재하는지 여부를 검색하는 문서 파일 검색부 및 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 상기 기준 반경 이내의 위치 정보를 갖는 문서 파일로, 적어도 하나의 문서 파일이 존재하는 것으로 검색되면, 상기 적어도 하나의 문서 파일 각각의 파일명으로 구성된 검색 결과 목록을 생성한 후, 상기 검색 결과 목록을, 상기 문서 파일 검색 요청에 대한 검색 결과로 지정하여 상기 제1 사용자 단말로 전송하는 검색 결과 전송부를 포함한다.A document management service server for managing document files based on location information according to an embodiment of the present invention stores a plurality of document files and location information of a point where each of the plurality of document files was created in correspondence with each other. A first location information request requesting transmission of the current location information of the first user terminal to the first user terminal when a location information-based document file search request is received from the document file database and the first user terminal. Optionally, when first location information is received from the first user terminal, a document file having location information within a preset reference radius from the first location information among the plurality of document files stored in the document file database. A document file search unit for searching whether a document file exists and a document file having location information within the reference radius from the first location information among the plurality of document files stored in the document file database, at least one If it is found that a document file exists, a search result list composed of the file names of each of the at least one document file is created, and then the search result list is designated as a search result for the document file search request by the first user. and a search result transmission unit for transmitting to a terminal.
또한, 본 발명의 일실시예에 따른 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버의 동작 방법은 복수의 문서 파일들과, 상기 복수의 문서 파일들 각각이 생성된 지점의 위치 정보가 서로 대응되어 저장되어 있는 문서 파일 데이터베이스를 유지하는 단계, 제1 사용자 단말로부터, 위치 정보 기반의 문서 파일 검색 요청이 수신되면, 상기 제1 사용자 단말로, 상기 제1 사용자 단말의 현재 위치 정보의 전송을 요청하는 단계, 상기 제1 사용자 단말로부터 제1 위치 정보가 수신되면, 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 사전 설정된 기준 반경 이내의 위치 정보를 갖는 문서 파일이 존재하는지 여부를 검색하는 단계 및 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 상기 기준 반경 이내의 위치 정보를 갖는 문서 파일로, 적어도 하나의 문서 파일이 존재하는 것으로 검색되면, 상기 적어도 하나의 문서 파일 각각의 파일명으로 구성된 검색 결과 목록을 생성한 후, 상기 검색 결과 목록을, 상기 문서 파일 검색 요청에 대한 검색 결과로 지정하여 상기 제1 사용자 단말로 전송하는 단계를 포함한다.In addition, a method of operating a document management service server for managing document files based on location information according to an embodiment of the present invention includes location information of a plurality of document files and a point where each of the plurality of document files is created. Maintaining a document file database in which are stored in correspondence with each other, when a location information-based document file search request is received from a first user terminal, the current location information of the first user terminal is sent to the first user terminal. Requesting transmission, when the first location information is received from the first user terminal, location information within a predetermined reference radius from the first location information among the plurality of document files stored in the document file database Searching whether a document file having a document file exists, and among the plurality of document files stored in the document file database, a document file having location information within the reference radius from the first location information, at least one If it is found that the document files exist, a search result list consisting of the file names of each of the at least one document file is created, and then the search result list is designated as a search result for the document file search request, so that the first document file is searched for. and transmitting to a user terminal.
본 발명은 문서 파일이 생성된 지점의 위치와 근접한 위치에서만 해당 문서 파일에 접근할 수 있도록 하는 문서 관리 서비스 서버 및 그 동작 방법을 제시함으로써, 문서 파일이 생성된 지점이 아닌 외부의 다른 지점에 위치하고 있는 제3자에 의한 문서 파일의 노출 문제를 해소할 수 있다.The present invention provides a document management service server and its operation method that allow access to a document file only from a location close to the location where the document file is created, and is located at a point other than the point where the document file is created. It is possible to solve the problem of exposure of document files by third parties.
도 1은 본 발명의 일실시예에 따른 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버의 구조를 도시한 도면이다.
도 2는 본 발명의 일실시예에 따른 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버의 동작 방법을 도시한 순서도이다.1 is a diagram showing the structure of a document management service server for managing document files based on location information according to an embodiment of the present invention.
2 is a flowchart illustrating an operating method of a document management service server for managing document files based on location information according to an embodiment of the present invention.
이하에서는 본 발명에 따른 실시예들을 첨부된 도면을 참조하여 상세하게 설명하기로 한다. 이러한 설명은 본 발명을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 발명의 사상 및 기술 범위에 포함되는 모든 변경, 균등물 내지 대체물을 포함하는 것으로 이해되어야 한다. 각 도면을 설명하면서 유사한 참조부호를 유사한 구성요소에 대해 사용하였으며, 다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 본 명세서 상에서 사용되는 모든 용어들은 본 발명이 속하는 기술분야에서 통상의 지식을 가진 사람에 의해 일반적으로 이해되는 것과 동일한 의미를 가지고 있다.Hereinafter, embodiments according to the present invention will be described in detail with reference to the accompanying drawings. This description is not intended to limit the present invention to specific embodiments, but should be understood to include all modifications, equivalents, and substitutes included in the spirit and scope of the present invention. While describing each drawing, similar reference numerals have been used for similar components, and unless otherwise defined, all terms used in this specification, including technical or scientific terms, are common knowledge in the art to which the present invention belongs. has the same meaning as commonly understood by the person who has it.
본 문서에서, 어떤 부분이 어떤 구성요소를 "포함"한다고 할 때, 이는 특별히 반대되는 기재가 없는 한 다른 구성요소를 제외하는 것이 아니라 다른 구성요소를 더 포함할 수 있다는 것을 의미한다. 또한, 본 발명의 다양한 실시예들에 있어서, 각 구성요소들, 기능 블록들 또는 수단들은 하나 또는 그 이상의 하부 구성요소로 구성될 수 있고, 각 구성요소들이 수행하는 전기, 전자, 기계적 기능들은 전자회로, 집적회로, ASIC(Application Specific Integrated Circuit) 등 공지된 다양한 소자들 또는 기계적 요소들로 구현될 수 있으며, 각각 별개로 구현되거나 2 이상이 하나로 통합되어 구현될 수도 있다. In this document, when a certain component is said to "include", it means that it may further include other components without excluding other components unless otherwise stated. In addition, in various embodiments of the present invention, each component, functional block, or means may be composed of one or more sub-components, and the electrical, electronic, and mechanical functions performed by each component are electronic It may be implemented with various known elements or mechanical elements such as circuits, integrated circuits, ASICs (Application Specific Integrated Circuits), and may be implemented separately or two or more may be integrated into one.
한편, 첨부된 블록도의 블록들이나 흐름도의 단계들은 범용 컴퓨터, 특수용 컴퓨터, 휴대용 노트북 컴퓨터, 네트워크 컴퓨터 등 데이터 프로세싱이 가능한 장비의 프로세서나 메모리에 탑재되어 지정된 기능들을 수행하는 컴퓨터 프로그램 명령들(instructions)을 의미하는 것으로 해석될 수 있다. 이들 컴퓨터 프로그램 명령들은 컴퓨터 장치에 구비된 메모리 또는 컴퓨터에서 판독 가능한 메모리에 저장될 수 있기 때문에, 블록도의 블록들 또는 흐름도의 단계들에서 설명된 기능들은 이를 수행하는 명령 수단을 내포하는 제조물로 생산될 수도 있다. 아울러, 각 블록 또는 각 단계는 특정된 논리적 기능(들)을 실행하기 위한 하나 이상의 실행 가능한 명령들을 포함하는 모듈, 세그먼트 또는 코드의 일부를 나타낼 수 있다. 또, 몇 가지 대체 가능한 실시예들에서는 블록들 또는 단계들에서 언급된 기능들이 정해진 순서와 달리 실행되는 것도 가능함을 주목해야 한다. 예컨대, 잇달아 도시되어 있는 두 개의 블록들 또는 단계들은 실질적으로 동시에 수행되거나, 역순으로 수행될 수 있으며, 경우에 따라 일부 블록들 또는 단계들이 생략된 채로 수행될 수도 있다.On the other hand, the blocks of the accompanying block diagram or the steps of the flowchart are computer program instructions that perform designated functions by being loaded into a processor or memory of a device capable of data processing, such as a general-purpose computer, a special purpose computer, a portable notebook computer, and a network computer. can be interpreted as meaning Since these computer program instructions may be stored in a memory included in a computer device or in a computer readable memory, the functions described in blocks of a block diagram or steps of a flowchart are produced as a product containing instruction means for performing them. It could be. Further, each block or each step may represent a module, segment or portion of code that includes one or more executable instructions for executing specified logical function(s). Also, it should be noted that in some alternative embodiments, functions mentioned in blocks or steps may be executed out of a predetermined order. For example, two blocks or steps shown in succession may be performed substantially simultaneously or in reverse order, and in some cases, some blocks or steps may be omitted.
도 1은 본 발명의 일실시예에 따른 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버의 구조를 도시한 도면이다.1 is a diagram showing the structure of a document management service server for managing document files based on location information according to an embodiment of the present invention.
도 1을 참조하면, 본 발명의 일실시예에 따른 문서 관리 서비스 서버(110)는 문서 파일 데이터베이스(111), 제1 위치 정보 요청부(112), 문서 파일 검색부(113) 및 검색 결과 전송부(114)를 포함한다.Referring to FIG. 1, a document
문서 파일 데이터베이스(111)에는 복수의 문서 파일들과, 상기 복수의 문서 파일들 각각이 생성된 지점의 위치 정보가 서로 대응되어 저장되어 있다.In the
예컨대, 문서 파일 데이터베이스(111)에는 하기의 표 1과 같은 복수의 문서 파일들과, 상기 복수의 문서 파일들 각각이 생성된 지점의 위치 정보가 서로 대응되어 저장되어 있을 수 있다.For example, the
제1 위치 정보 요청부(112)는 제1 사용자 단말(131)로부터, 위치 정보 기반의 문서 파일 검색 요청이 수신되면, 제1 사용자 단말(131)로, 제1 사용자 단말(131)의 현재 위치 정보의 전송을 요청한다.When receiving a location information-based document file search request from the
문서 파일 검색부(113)는 제1 사용자 단말(131)로부터 제1 위치 정보가 수신되면, 문서 파일 데이터베이스(111)에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 사전 설정된 기준 반경 이내의 위치 정보를 갖는 문서 파일이 존재하는지 여부를 검색한다.When the first location information is received from the
검색 결과 전송부(114)는 문서 파일 데이터베이스(111)에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 상기 기준 반경 이내의 위치 정보를 갖는 문서 파일로, 적어도 하나의 문서 파일이 존재하는 것으로 검색되면, 상기 적어도 하나의 문서 파일 각각의 파일명으로 구성된 검색 결과 목록을 생성한 후, 상기 검색 결과 목록을, 상기 문서 파일 검색 요청에 대한 검색 결과로 지정하여 제1 사용자 단말(131)로 전송한다.The search
이하에서는, 제1 위치 정보 요청부(112), 문서 파일 검색부(113) 및 검색 결과 전송부(114)의 동작을 예를 들어, 상세히 설명하기로 한다.Hereinafter, operations of the first location
먼저, 사전 설정된 기준 반경이 '100m'라고 하고, 문서 관리 서비스 서버(110)에 제1 사용자 단말(131)로부터, 위치 정보 기반의 문서 파일 검색 요청이 수신되었다고 가정하자.First, it is assumed that the preset reference radius is '100m' and the document
그러면, 제1 위치 정보 요청부(112)는 제1 사용자 단말(131)로, 제1 사용자 단말(131)의 현재 위치 정보의 전송을 요청할 수 있다.Then, the first location
이에 대응하여, 문서 관리 서비스 서버(110)에 제1 사용자 단말(131)로부터, '위치 정보 6'이 수신되었다고 하는 경우, 문서 파일 검색부(113)는 상기 표 1과 같은 문서 파일 데이터베이스(111)에 저장되어 있는 상기 복수의 문서 파일들인 '문서 파일 1, 문서 파일 2, 문서 파일 3, 문서 파일 4, 문서 파일 5, ...' 중, '위치 정보 6'으로부터 반경 '100m' 이내의 위치 정보를 갖는 문서 파일이 존재하는지 여부를 검색할 수 있다.Correspondingly, when it is assumed that the document
그 결과, '문서 파일 1, 문서 파일 2, 문서 파일 3, 문서 파일 4, 문서 파일 5, ...' 중, '위치 정보 6'으로부터 반경 '100m' 이내의 위치 정보를 갖는 문서 파일로, '문서 파일 2, 문서 파일 3, 문서 파일 5'가 존재하는 것으로 검색되었다고 가정하자.As a result, among 'document file 1, document file 2, document file 3, document file 4, document file 5, ...', a document file having location information within a radius of '100m' from 'location information 6', Assume that 'document file 2, document file 3, and document file 5' are found to exist.
이때, '문서 파일 2, 문서 파일 3, 문서 파일 5' 각각의 파일명이 '파일명 2, 파일명 3, 파일명 5'라고 하는 경우, 검색 결과 전송부(114)는 하기의 표 2와 같은 검색 결과 목록을 생성한 후, 하기의 표 2와 같은 검색 결과 목록을, 상기 문서 파일 검색 요청에 대한 검색 결과로 지정하여 제1 사용자 단말(131)로 전송할 수 있다.At this time, when the file names of 'document file 2, document file 3, and document file 5' are 'file name 2, file name 3, and file name 5', the search
본 발명의 일실시예에 따르면, 문서 관리 서비스 서버(110)는 제1 IP 주소 확인부(115), 제1 위치 정보 확인부(116) 및 문서 파일 전송부(117)를 더 포함할 수 있다.According to one embodiment of the present invention, the document
제1 IP 주소 확인부(115)는 검색 결과 전송부(114)에 의해 상기 검색 결과 목록이 제1 사용자 단말(131)로 전송된 이후, 제1 사용자 단말(131)로부터, 상기 적어도 하나의 문서 파일 중 어느 하나인 제1 문서 파일에 대한 전송 요청이 수신되면, 제1 사용자 단말(131)에 할당되어 있는 제1 IP(Internet Protocol) 주소를 확인한다.After the search result list is transmitted to the
제1 위치 정보 확인부(116)는 제1 IP 주소 확인부(115)에 의해 상기 제1 IP 주소가 확인되면, 사전 설정된 IP 주소 위치 추적 서비스 서버(140)로, 상기 제1 IP 주소에 따른 위치 정보의 제공을 요청하여, IP 주소 위치 추적 서비스 서버(140)로부터, 상기 제1 IP 주소에 따른 위치 정보로, 제2 위치 정보가 수신되면, 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 사전 설정된 기준 거리 이내인지 여부를 확인한다.When the first IP address is confirmed by the first IP
이하에서는, 제1 IP 주소 확인부(115) 및 제1 위치 정보 확인부(116)의 동작을 예를 들어, 상세히 설명하기로 한다.Hereinafter, operations of the first IP
먼저, 사전 설정된 기준 거리를 '50m'라고 하고, 전술한 예와 같이, 검색 결과 전송부(114)에 의해, 상기 표 2와 같은 검색 결과 목록이 제1 사용자 단말(131)로 전송되었다고 하며, 그 이후, 문서 관리 서비스 서버(110)에 제1 사용자 단말(131)로부터, '문서 파일 3'에 대한 전송 요청이 수신되었다고 가정하자. First, the preset reference distance is set to '50m', and, as in the above example, the search result list shown in Table 2 is transmitted to the
그러면, 제1 IP 주소 확인부(115)는 제1 사용자 단말(131)에 할당되어 있는 제1 IP 주소를 확인할 수 있다.Then, the first IP
그 결과, 제1 사용자 단말(131)에 할당되어 있는 제1 IP 주소가, 'IP 주소 1'과 같이 확인되었다고 하는 경우, 제1 위치 정보 확인부(116)는 사전 설정된 IP 주소 위치 추적 서비스 서버(140)로, 'IP 주소 1'에 따른 위치 정보의 제공을 요청할 수 있다.As a result, when it is determined that the first IP address assigned to the
이에 대응하여, 문서 관리 서비스 서버(110)에 IP 주소 위치 추적 서비스 서버(140)로부터, 'IP 주소 1'에 따른 위치 정보로, '위치 정보 7'이 수신되었다고 하는 경우, 제1 위치 정보 확인부(116)는 '위치 정보 6'과 '위치 정보 7' 간의 이격 거리가 '50m' 이내인지 여부를 확인할 수 있다.Correspondingly, when it is assumed that the document
이렇게, 제1 위치 정보 확인부(116)가, 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인지 여부를 확인한 결과, 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 문서 파일 전송부(117)는 문서 파일 데이터베이스(111)로부터 상기 제1 문서 파일을 추출하여 제1 사용자 단말(131)로 전송한다.In this way, as a result of the first location
이때, 본 발명의 일실시예에 따르면, 문서 파일 전송부(117)는 상기 제1 문서 파일을 제1 사용자 단말(131)로 전송할 때, 상기 제1 문서 파일이 타인에게 노출되는 것을 방지하기 위해서, 상기 제1 문서 파일을 암호화하여 제1 사용자 단말(131)로 전송할 수 있다.At this time, according to one embodiment of the present invention, when the document
이와 관련해서, 본 발명에 일실시예에 따르면, 문서 파일 전송부(117)는 상기 제1 문서 파일을 암호화하여 제1 사용자 단말(131)로 전송하기 위한 구체적인 구성으로, 테이블 유지부(118), 암호화 이벤트 발생부(119), 일련번호 추출부(120), 연산 코드 생성부(121), 다항식 생성부(122), 암호화키 생성부(123) 및 암호화 전송부(124)를 포함할 수 있다.In this regard, according to an embodiment of the present invention, the document
테이블 유지부(118)는 제1 사용자 단말(131)과 사전 공유하고 있는 기준 위치 정보 테이블을 저장하여 유지한다.The
여기서, 상기 기준 위치 정보 테이블은, 사전 설정된 복수의 기준 위치 정보들과, 상기 복수의 기준 위치 정보들 각각에 대한 사전 할당된 k(k는 2 이상의 자연수임)자릿수의 일련번호가 기록된 테이블을 의미한다.Here, the reference position information table includes a table in which a plurality of preset reference position information and a pre-allocated serial number of k (k is a natural number equal to or greater than 2) digits for each of the plurality of reference position information are recorded. it means.
예컨대, k를 '3'이라고 하는 경우, 테이블 유지부(118)는 하기의 표 3과 같은 기준 위치 정보 테이블을 저장하여 유지할 수 있다.For example, when k is set to '3', the
암호화 이벤트 발생부(119)는 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가 상기 기준 거리 이내인 것으로 확인되면, 문서 파일 데이터베이스(111)로부터 상기 제1 문서 파일을 추출한 후, 상기 제1 문서 파일을 암호화하여 전송하기 위한 암호화 이벤트를 발생시킨다.When it is confirmed that the separation distance between the first location information and the second location information is within the reference distance, the encryption
일련번호 추출부(120)는 암호화 이벤트 발생부(119)에 의해 상기 암호화 이벤트가 발생되면, 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 제2 일련번호를 추출한다.When the encryption event is generated by the encryption
연산 코드 생성부(121)는 일련번호 추출부(120)에 의해 상기 제1 일련번호와 상기 제2 일련번호가 추출되면, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로(modulo)-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제2 연산 코드를 생성한다.When the first serial number and the second serial number are extracted by the serial
여기서, 모듈로-2 연산은 피제수를 2로 나누는 나눗셈을 수행하여, 그에 대한 나머지(remainder)를 산출하는 연산을 의미한다.Here, the modulo-2 operation means an operation of dividing a dividend by 2 and calculating a remainder thereto.
다항식 생성부(122)는 연산 코드 생성부(121)에 의해 상기 제1 연산 코드와 상기 제2 연산 코드가 생성되면, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제2 다항식을 생성한다.When the first operation code and the second operation code are generated by the operation
암호화키 생성부(123)는 다항식 생성부(122)에 의해 상기 제1 다항식과 상기 제2 다항식이 생성되면, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 연산 다항식을 생성한 후, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 시드(seed) 코드를 생성한 후, 상기 시드 코드를 사전 설정된 암호화키 생성 함수에 입력으로 인가하여 제1 암호화키를 생성한다.When the first polynomial and the second polynomial are generated by the
암호화 전송부(124)는 암호화키 생성부(123)에 의해 상기 제1 암호화키가 생성되면, 상기 제1 문서 파일을 상기 제1 암호화키로 암호화함으로써 제1 암호화 파일을 생성한 후, 상기 제1 암호화 파일과 상기 암호화키 생성 함수를 제1 사용자 단말(131)로 전송한다.When the first encryption key is generated by the
이하에서는, 암호화 이벤트 발생부(119), 일련번호 추출부(120), 연산 코드 생성부(121), 다항식 생성부(122), 암호화키 생성부(123) 및 암호화 전송부(124)의 동작을 예를 들어, 상세히 설명하기로 한다.Hereinafter, operations of the encryption
먼저, 본 발명에서 사용되는 각 2진 다항식의 계수는, 0차 항의 계수를 포함하는 개념인 것으로 가정한다.First, it is assumed that the coefficient of each binary polynomial used in the present invention is a concept including the coefficient of the 0th order term.
이러한 상황에서, 전술한 예와 같이, 제1 위치 정보 확인부(116)가, '위치 정보 6'과 '위치 정보 7' 간의 이격 거리가 상기 기준 거리인 '50m' 이내인지 여부를 확인한 결과, '위치 정보 6'과 '위치 정보 7' 간의 이격 거리가 '50m' 이내인 것으로 확인되었다고 가정하자.In this situation, as in the above example, as a result of checking whether the distance between the 'location information 6' and the 'location information 7' is within the reference distance '50 m', the first location
그러면, 암호화 이벤트 발생부(119)는 상기 표 1과 같은 문서 파일 데이터베이스(111)로부터 '문서 파일 3'을 추출한 후, '문서 파일 3'을 암호화하여 전송하기 위한 암호화 이벤트를 발생시킬 수 있다.Then, the encryption
그러면, 일련번호 추출부(120)는 상기 표 3과 같은 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들인 '기준 위치 정보 1, 기준 위치 정보 2, 기준 위치 정보 3, 기준 위치 정보 4, 기준 위치 정보 5, ...' 중 '위치 정보 6'과 가장 가까운 거리의 제1 기준 위치 정보를 확인할 수 있다.Then, the serial
그 결과, '기준 위치 정보 1, 기준 위치 정보 2, 기준 위치 정보 3, 기준 위치 정보 4, 기준 위치 정보 5, ...' 중 '위치 정보 6'과 가장 가까운 거리의 제1 기준 위치 정보가 '기준 위치 정보 5'인 것으로 확인되었다고 하는 경우, 일련번호 추출부(120)는 '기준 위치 정보 5'에 대한 일련번호인 '936'을 제1 일련번호로 추출할 수 있다.As a result, the first reference position information closest to 'position information 6' among 'reference position information 1, reference position information 2, reference position information 3, reference position information 4, reference position information 5, ...' If it is confirmed that the 'reference position information 5' is confirmed, the serial
또한, 일련번호 추출부(120)는 상기 표 3과 같은 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들인 '기준 위치 정보 1, 기준 위치 정보 2, 기준 위치 정보 3, 기준 위치 정보 4, 기준 위치 정보 5, ...' 중 '위치 정보 6'과 가장 먼 거리의 제1 기준 위치 정보를 확인할 수 있다.In addition, the
그 결과, '기준 위치 정보 1, 기준 위치 정보 2, 기준 위치 정보 3, 기준 위치 정보 4, 기준 위치 정보 5, ...' 중 '위치 정보 6'과 가장 먼 거리의 제2 기준 위치 정보가 '기준 위치 정보 1'인 것으로 확인되었다고 하는 경우, 일련번호 추출부(120)는 '기준 위치 정보 1'에 대한 일련번호인 '175'를 제2 일련번호로 추출할 수 있다.As a result, among 'reference position information 1, reference position information 2, reference position information 3, reference position information 4, reference position information 5, ...', 'position information 6' and the second reference position information furthest from each other are If it is confirmed that the 'reference position information 1' is confirmed, the serial
그러면, 연산 코드 생성부(121)는 상기 제1 일련번호인 '936'을 구성하는 '3'개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 '3'비트의 제1 연산 코드를 '110'과 같이 생성할 수 있다.Then, the operation
또한, 연산 코드 생성부(121)는 상기 제2 일련번호인 '175'를 구성하는 '3'개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 '3'비트의 제2 연산 코드를 '111'과 같이 생성할 수 있다.In addition, the operation
그러면, 다항식 생성부(122)는 최고차수가 '2'인 2진 다항식의 각 계수를, 상기 제1 연산 코드인 '110'을 구성하는 '3'개의 비트값들로 지정함으로써 제1 다항식을 ''과 같이 생성할 수 있고, 최고차수가 '2'인 2진 다항식의 각 계수를, 상기 제2 연산 코드인 '111'을 구성하는 '3'개의 비트값들로 지정함으로써 제2 다항식을 ''과 같이 생성할 수 있다.Then, the
그러고 나서, 암호화키 생성부(123)는 상기 제1 다항식인 ''과 상기 제2 다항식인 ''을 서로 곱하여 최고차수가 '4'가 되는 2진 다항식인 연산 다항식을 생성할 수 있다.Then, the encryption
여기서, 암호화키 생성부(123)는 상기 연산 다항식을 생성할 때, 상기 연산 다항식의 각 계수를 2진 값으로 감산해야 하기 때문에, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 생성된 다항식의 각 계수에 대해, 모듈로-2 연산을 수행하였을 때의 결과 값을, 상기 연산 다항식의 각 계수로 연산할 수 있다.Here, when the
결국, 암호화키 생성부(123)는 상기 연산 다항식을 ''과 같이 생성할 수 있다.Eventually, the
그러고 나서, 암호화키 생성부(123)는 상기 연산 다항식의 각 계수인 '1, 0, 0, 1, 0'을 비트열로 구성함으로써, '5'비트의 시드 코드를 '10010'과 같이 생성할 수 있다.Then, the encryption
그 이후, 암호화키 생성부(123)는 상기 시드 코드인 '10010'을 사전 설정된 암호화키 생성 함수에 입력으로 인가하여 '암호화키 1'을 생성할 수 있다.Thereafter, the encryption
이때, 본 발명의 일실시예에 따르면, 상기 암호화키 생성 함수는, 사전 설정된 소정의 해시 함수일 수 있다.In this case, according to an embodiment of the present invention, the encryption key generating function may be a predetermined hash function.
그러면, 암호화 전송부(124)는 '문서 파일 3'을 '암호화 키 1'로 암호화함으로써, '암호화 파일 1'을 생성한 후, '암호화 파일 1'과 상기 암호화키 생성 함수를 제1 사용자 단말(131)로 전송할 수 있다.Then, the
이때, 본 발명의 일실시예에 따르면, 제1 사용자 단말(131)은 메모리 상에 상기 기준 위치 정보 테이블을 저장하고 있고, 문서 관리 서비스 서버(110)로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 제1 위치 정보를 기초로, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터 상기 제1 일련번호와 상기 제2 일련번호를 추출하여, 상기 제1 일련번호와 상기 제2 일련번호를 기초로 상기 시드 코드를 생성하고, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성한 후, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원할 수 있다.At this time, according to an embodiment of the present invention, the
구체적으로, 본 발명의 일실시예에 따르면, 제1 사용자 단말(131)은 문서 관리 서비스 서버(110)로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 상기 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 상기 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 상기 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 상기 제2 일련번호를 추출한 후, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제2 연산 코드를 생성한 후, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제2 다항식을 생성한 후, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 상기 연산 다항식을 생성하고, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 상기 시드 코드를 생성한 후, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성하고, 상기 제1 암호화키가 생성되면, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원할 수 있다.Specifically, according to one embodiment of the present invention, when the
이하에서는, 제1 사용자 단말(131)의 동작을 예를 들어, 상세히 설명하기로 한다.Hereinafter, the operation of the
먼저, 전술한 예와 같이, k를 '3'이라고 하고, 제1 사용자 단말(131)의 메모리 상에는 문서 관리 서비스 서버(110)와 사전 공유하고 있는 상기 표 3과 같은 기준 위치 정보 테이블이 저장되어 있다고 가정하자. 또한, 전술한 예와 같이, 암호화 전송부(124)가 '암호화 파일 1'과 상기 암호화키 생성 함수를 제1 사용자 단말(131)로 전송함에 따라, 제1 사용자 단말(131)에, '암호화 파일 1'과 상기 암호화키 생성 함수가 수신되었다고 가정하자.First, as in the above example, k is set to '3', and a reference location information table such as Table 3 previously shared with the document
그러면, 제1 사용자 단말(131)은 상기 메모리 상에 저장되어 있는 상기 표 3과 같은 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들인 '기준 위치 정보 1, 기준 위치 정보 2, 기준 위치 정보 3, 기준 위치 정보 4, 기준 위치 정보 5, ...' 중 '위치 정보 6'과 가장 가까운 거리의 '기준 위치 정보 5'를 확인하여, '기준 위치 정보 5'에 대한 일련번호인 '936'을 상기 제1 일련번호로 추출할 수 있다.Then, the
또한, 제1 사용자 단말(131)은 상기 표 3과 같은 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들인 '기준 위치 정보 1, 기준 위치 정보 2, 기준 위치 정보 3, 기준 위치 정보 4, 기준 위치 정보 5, ...' 중 '위치 정보 6'과 가장 먼 거리의 '기준 위치 정보 1'을 확인하여, '기준 위치 정보 1'에 대한 일련번호인 '175'를 상기 제2 일련번호로 추출할 수 있다.In addition, the
그러고 나서, 제1 사용자 단말(131)은 상기 제1 일련번호인 '936'을 구성하는 '3'개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 '3'비트의 상기 제1 연산 코드를 '110'과 같이 생성할 수 있고, 상기 제2 일련번호인 '175'를 구성하는 '3'개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 '3'비트의 상기 제2 연산 코드를 '111'과 같이 생성할 수 있다.Then, the
그 이후, 제1 사용자 단말(131)은 최고차수가 '2'인 2진 다항식의 각 계수를, 상기 제1 연산 코드인 '110'을 구성하는 '3'개의 비트값들로 지정함으로써 상기 제1 다항식을 ''과 같이 생성할 수 있고, 최고차수가 '2'인 2진 다항식의 각 계수를, 상기 제2 연산 코드인 '111'을 구성하는 '3'개의 비트값들로 지정함으로써 상기 제2 다항식을 ''과 같이 생성할 수 있다.After that, the
그러고 나서, 제1 사용자 단말(131)은 상기 제1 다항식인 ''과 상기 제2 다항식인 ''을 서로 곱하여 최고차수가 '4'가 되는 2진 다항식인 상기 연산 다항식을 ''과 같이 생성할 수 있다.Then, the
그 이후, 제1 사용자 단말(131)은, 상기 연산 다항식의 각 계수인 '1, 0, 0, 1, 0'을 비트열로 구성함으로써 '5'비트의 상기 시드 코드를 '10010'과 같이 생성할 수 있다.After that, the
그러고 나서, 제1 사용자 단말(131)은 상기 시드 코드인 '10010'을 상기 암호화키 생성 함수에 입력으로 인가하여 '암호화키 1'을 생성할 수 있다.Then, the
이때, 전술한 예에 따르면, '암호화 파일 1'은, '문서 파일 3'이 '암호화키 1'로 암호화됨으로써 생성된 암호화 파일이므로, 제1 사용자 단말(131)은 '암호화 파일 1'을 '암호화키 1'로 복호화함으로써, '문서 파일 3'을 정상적으로 복원할 수 있다.At this time, according to the above example, 'encryption file 1' is an encryption file generated by encrypting 'document file 3' with 'encryption key 1', so the
본 발명의 일실시예에 따르면, 문서 관리 서비스 서버(110)는 제2 위치 정보 요청부(125), 제2 IP 주소 확인부(126), 제2 위치 정보 확인부(127) 및 문서 파일 저장 처리부(128)를 더 포함할 수 있다.According to one embodiment of the present invention, the document
제2 위치 정보 요청부(125)는 제2 사용자 단말(132)로부터, 제2 사용자 단말(132)에서 작성된 신규 전자 문서에 대한 제2 문서 파일이 수신되면서, 상기 제2 문서 파일에 대한 저장 요청 명령이 수신되면, 제2 사용자 단말(132)로, 제2 사용자 단말(132)의 현재 위치 정보의 전송을 요청한다.When a second document file for a new electronic document created in the
제2 IP 주소 확인부(126)는 제2 사용자 단말(132)로부터 제3 위치 정보가 수신되면, 제2 사용자 단말(132)에 할당되어 있는 제2 IP 주소를 확인한다.When third location information is received from the
제2 위치 정보 확인부(127)는 제2 IP 주소 확인부(126)에 의해 상기 제2 IP 주소가 확인되면, IP 주소 위치 추적 서비스 서버(140)로, 상기 제2 IP 주소에 따른 위치 정보의 제공을 요청하여, IP 주소 위치 추적 서비스 서버(140)로부터, 상기 제2 IP 주소에 따른 위치 정보로, 제4 위치 정보가 수신되면, 상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인지 여부를 확인한다.When the second IP address is confirmed by the second IP
문서 파일 저장 처리부(128)는 상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 상기 제2 문서 파일을 상기 제3 위치 정보와 대응시켜 문서 파일 데이터베이스(111)에 저장한다.When it is determined that the separation distance between the third location information and the fourth location information is within the reference distance, the document file
이하에서는, 제2 위치 정보 요청부(125), 제2 IP 주소 확인부(126), 제2 위치 정보 확인부(127) 및 문서 파일 저장 처리부(128)의 동작을 예를 들어, 상세히 설명하기로 한다.Hereinafter, operations of the second location
먼저, 전술한 예와 같이, 상기 기준 거리를 '50m'라고 하고, 문서 관리 서비스 서버(110)에 제2 사용자 단말(132)로부터, 제2 사용자 단말(132)에서 작성된 신규 전자 문서에 대한 '문서 파일 6'이 수신되면서, '문서 파일 6'에 대한 저장 요청 명령이 수신되었다고 가정하자.First, as in the foregoing example, the reference distance is set to '50 m', and the document
그러면, 제2 위치 정보 요청부(125)는 제2 사용자 단말(132)로, 제2 사용자 단말(132)의 현재 위치 정보의 전송을 요청할 수 있다.Then, the second location
이에 대응하여, 문서 관리 서비스 서버(110)에 제2 사용자 단말(132)로부터, '위치 정보 8'이 수신되었다고 하는 경우, 제2 IP 주소 확인부(126)는 제2 사용자 단말(132)에 할당되어 있는 제2 IP 주소를 확인할 수 있다.Correspondingly, when it is determined that the document
그 결과, 제2 사용자 단말(132)에 할당되어 있는 제2 IP 주소가, 'IP 주소 2'와 같이 확인되었다고 하는 경우, 제2 위치 정보 확인부(127)는 IP 주소 위치 추적 서비스 서버(140)로, 'IP 주소 2'에 따른 위치 정보의 제공을 요청할 수 있다.As a result, when it is determined that the second IP address allocated to the
이에 대응하여, 문서 관리 서비스 서버(110)에 IP 주소 위치 추적 서비스 서버(140)로부터, 'IP 주소 2'에 따른 위치 정보로, '위치 정보 9'가 수신되었다고 하는 경우, 제2 위치 정보 확인부(127)는 '위치 정보 8'과 '위치 정보 9' 간의 이격 거리가, '50m' 이내인지 여부를 확인할 수 있다.Correspondingly, when it is said that the document
그 결과, '위치 정보 8'과 '위치 정보 9' 간의 이격 거리가, '50m' 이내인 것으로 확인되었다고 하는 경우, 문서 파일 저장 처리부(128)는 하기의 표 4와 같이, '문서 파일 6'과 '위치 정보 8'을 대응시켜 상기 표 1과 같은 문서 파일 데이터베이스(111)에 저장할 수 있다.As a result, when it is confirmed that the separation distance between 'location information 8' and 'location information 9' is within '50m', the document file
도 2는 본 발명의 일실시예에 따른 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버의 동작 방법을 도시한 순서도이다.2 is a flowchart illustrating an operating method of a document management service server for managing document files based on location information according to an embodiment of the present invention.
단계(S210)에서는 복수의 문서 파일들과, 상기 복수의 문서 파일들 각각이 생성된 지점의 위치 정보가 서로 대응되어 저장되어 있는 문서 파일 데이터베이스를 유지한다.In step S210, a document file database is maintained in which a plurality of document files and location information of points where each of the plurality of document files is generated are stored in correspondence with each other.
단계(S220)에서는 제1 사용자 단말로부터, 위치 정보 기반의 문서 파일 검색 요청이 수신되면, 상기 제1 사용자 단말로, 상기 제1 사용자 단말의 현재 위치 정보의 전송을 요청한다.In step S220, when a location information-based document file search request is received from the first user terminal, transmission of current location information of the first user terminal is requested to the first user terminal.
단계(S230)에서는 상기 제1 사용자 단말로부터 제1 위치 정보가 수신되면, 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 사전 설정된 기준 반경 이내의 위치 정보를 갖는 문서 파일이 존재하는지 여부를 검색한다.In step S230, when the first location information is received from the first user terminal, location information within a predetermined reference radius from the first location information among the plurality of document files stored in the document file database. Searches whether a document file with
단계(S240)에서는 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 상기 기준 반경 이내의 위치 정보를 갖는 문서 파일로, 적어도 하나의 문서 파일이 존재하는 것으로 검색되면, 상기 적어도 하나의 문서 파일 각각의 파일명으로 구성된 검색 결과 목록을 생성한 후, 상기 검색 결과 목록을, 상기 문서 파일 검색 요청에 대한 검색 결과로 지정하여 상기 제1 사용자 단말로 전송한다.In step S240, it is searched for a document file having location information within the reference radius from the first location information among the plurality of document files stored in the document file database, and that at least one document file exists. After generating a search result list composed of the file names of each of the at least one document file, the search result list is designated as a search result for the document file search request and transmitted to the first user terminal.
이때, 본 발명의 일실시예에 따르면, 상기 문서 관리 서비스 서버의 동작 방법은 상기 검색 결과 목록이 상기 제1 사용자 단말로 전송된 이후, 상기 제1 사용자 단말로부터, 상기 적어도 하나의 문서 파일 중 어느 하나인 제1 문서 파일에 대한 전송 요청이 수신되면, 상기 제1 사용자 단말에 할당되어 있는 제1 IP 주소를 확인하는 단계, 상기 제1 IP 주소가 확인되면, 사전 설정된 IP 주소 위치 추적 서비스 서버로, 상기 제1 IP 주소에 따른 위치 정보의 제공을 요청하여, 상기 IP 주소 위치 추적 서비스 서버로부터, 상기 제1 IP 주소에 따른 위치 정보로, 제2 위치 정보가 수신되면, 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 사전 설정된 기준 거리 이내인지 여부를 확인하는 단계 및 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 상기 문서 파일 데이터베이스로부터 상기 제1 문서 파일을 추출하여 상기 제1 사용자 단말로 전송하는 단계를 더 포함할 수 있다.At this time, according to an embodiment of the present invention, the operating method of the document management service server may include, after the search result list is transmitted to the first user terminal, any one of the at least one document file from the first user terminal. When a transmission request for one first document file is received, checking a first IP address allocated to the first user terminal, and when the first IP address is confirmed, to a preset IP address location tracking service server. , When requesting provision of location information according to the first IP address and receiving second location information as location information according to the first IP address from the IP address location tracking service server, the first location information and Checking whether the separation distance between the second location information is within a preset reference distance, and if it is confirmed that the separation distance between the first location information and the second location information is within the reference distance, the document file The method may further include extracting the first document file from the database and transmitting it to the first user terminal.
이때, 본 발명의 일실시예에 따르면, 상기 제1 문서 파일을 추출하여 상기 제1 사용자 단말로 전송하는 단계는 상기 제1 사용자 단말과 사전 공유하고 있는 기준 위치 정보 테이블(상기 기준 위치 정보 테이블은, 사전 설정된 복수의 기준 위치 정보들과, 상기 복수의 기준 위치 정보들 각각에 대한 사전 할당된 k(k는 2 이상의 자연수임)자릿수의 일련번호가 기록된 테이블임)을 저장하여 유지하는 단계, 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가 상기 기준 거리 이내인 것으로 확인되면, 상기 문서 파일 데이터베이스로부터 상기 제1 문서 파일을 추출한 후, 상기 제1 문서 파일을 암호화하여 전송하기 위한 암호화 이벤트를 발생시키는 단계, 상기 암호화 이벤트가 발생되면, 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 제2 일련번호를 추출하는 단계, 상기 제1 일련번호와 상기 제2 일련번호가 추출되면, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제2 연산 코드를 생성하는 단계, 상기 제1 연산 코드와 상기 제2 연산 코드가 생성되면, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제2 다항식을 생성하는 단계, 상기 제1 다항식과 상기 제2 다항식이 생성되면, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 연산 다항식을 생성한 후, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 시드 코드를 생성한 후, 상기 시드 코드를 사전 설정된 암호화키 생성 함수에 입력으로 인가하여 제1 암호화키를 생성하는 단계 및 상기 제1 암호화키가 생성되면, 상기 제1 문서 파일을 상기 제1 암호화키로 암호화함으로써 제1 암호화 파일을 생성한 후, 상기 제1 암호화 파일과 상기 암호화키 생성 함수를 상기 제1 사용자 단말로 전송하는 단계를 포함할 수 있고, 상기 제1 사용자 단말은 메모리 상에 상기 기준 위치 정보 테이블을 저장하고 있고, 상기 문서 관리 서비스 서버로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 제1 위치 정보를 기초로, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터 상기 제1 일련번호와 상기 제2 일련번호를 추출하여, 상기 제1 일련번호와 상기 제2 일련번호를 기초로 상기 시드 코드를 생성하고, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성한 후, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원할 수 있다.At this time, according to an embodiment of the present invention, the step of extracting the first document file and transmitting the first document file to the first user terminal includes a reference position information table previously shared with the first user terminal (the reference position information table is , Storing and maintaining a table in which a plurality of preset reference position information and a serial number of pre-allocated k (k is a natural number equal to or greater than 2) digits for each of the plurality of reference position information are recorded; Encryption for encrypting and transmitting the first document file after extracting the first document file from the document file database when it is confirmed that the separation distance between the first location information and the second location information is within the reference distance. Generating an event, when the encryption event occurs, checking first reference location information having a closest distance to the first location information among the plurality of pieces of reference location information from the reference location information table; A first serial number of reference position information is extracted, and second reference position information of the furthest distance from the first position information is identified among the plurality of pieces of reference position information, and second reference position information of the second reference position information is obtained. Extracting the serial number, when the first serial number and the second serial number are extracted, a resultant value obtained by performing a modulo-2 operation on each of the k numbers constituting the first serial number A first operation code of k bits is generated by constructing a bit string, and a result value obtained when a modulo-2 operation is performed on each of the k numbers constituting the second serial number is formed into a bit string to k Generating a second operation code of bits, when the first operation code and the second operation code are generated, each coefficient of a binary polynomial having a highest degree k-1 is k constituting the first operation code A first polynomial is generated by specifying bit values, and a second polynomial is generated by specifying each coefficient of a binary polynomial whose highest degree is k-1 with k bit values constituting the second operation code. When the first polynomial and the second polynomial are generated, the first polynomial and the second polynomial are multiplied to generate an operating polynomial that is a binary polynomial having a highest degree of 2k-2, and then the operating polynomial Generating a 2k-1 bit seed code by configuring each coefficient of as a bit string, and then generating a first encryption key by applying the seed code as an input to a preset encryption key generation function, and the first encryption key is generated, generating a first encryption file by encrypting the first document file with the first encryption key, and then transmitting the first encryption file and the encryption key generation function to the first user terminal. The first user terminal stores the reference location information table in a memory, and when the first encryption file and the encryption key generating function are received from the document management service server, the first location information Based on this, the first serial number and the second serial number are extracted from the reference position information table stored in the memory, and the seed code is generated based on the first serial number and the second serial number. The first document file may be restored by applying the seed code as an input to the encryption key generation function to generate the first encryption key, and then decrypting the first encryption file with the first encryption key. .
이때, 본 발명의 일실시예에 따르면, 상기 제1 사용자 단말은 상기 문서 관리 서비스 서버로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 상기 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 상기 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 상기 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 상기 제2 일련번호를 추출한 후, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제2 연산 코드를 생성한 후, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제2 다항식을 생성한 후, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 상기 연산 다항식을 생성하고, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 상기 시드 코드를 생성한 후, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성하고, 상기 제1 암호화키가 생성되면, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원할 수 있다.At this time, according to an embodiment of the present invention, the first user terminal receives the first encryption file and the encryption key generation function from the document management service server, the reference location information stored in the memory. From the table, the first reference position information having a closest distance to the first position information among the plurality of reference position information is identified, the first serial number for the first reference position information is extracted, and the plurality of reference position information is extracted. Among the pieces of reference position information, the second reference position information of the farthest distance from the first position information is identified, the second serial number for the second reference position information is extracted, and the first serial number is configured. The first operation code of k bits is generated by constructing a resultant value when a modulo-2 operation is performed on each of the k numbers in a bit string, and the k numbers constituting the second serial number After generating the k-bit second operation code by configuring the resultant value when the modulo-2 operation is performed on each of them into a bit string, each coefficient of the binary polynomial having the highest order k-1 is The first polynomial is generated by specifying k bit values constituting the first operation code, and each coefficient of the binary polynomial having the highest order k-1 is k bit values constituting the second operation code. After generating the second polynomial by specifying , the first polynomial and the second polynomial are multiplied with each other to generate the operation polynomial that is a binary polynomial whose highest degree is 2k-2, and each coefficient of the operation polynomial is generated. After generating the seed code of 2k-1 bits by configuring as a bit string, applying the seed code as an input to the encryption key generation function to generate the first encryption key, and when the first encryption key is generated , The first document file may be restored by decrypting the first encrypted file with the first encryption key.
또한, 본 발명의 일실시예에 따르면, 상기 문서 관리 서비스 서버의 동작 방법은 제2 사용자 단말로부터, 상기 제2 사용자 단말에서 작성된 신규 전자 문서에 대한 제2 문서 파일이 수신되면서, 상기 제2 문서 파일에 대한 저장 요청 명령이 수신되면, 상기 제2 사용자 단말로, 상기 제2 사용자 단말의 현재 위치 정보의 전송을 요청하는 단계, 상기 제2 사용자 단말로부터 제3 위치 정보가 수신되면, 상기 제2 사용자 단말에 할당되어 있는 제2 IP 주소를 확인하는 단계, 상기 제2 IP 주소가 확인되면, 상기 IP 주소 위치 추적 서비스 서버로, 상기 제2 IP 주소에 따른 위치 정보의 제공을 요청하여, 상기 IP 주소 위치 추적 서비스 서버로부터, 상기 제2 IP 주소에 따른 위치 정보로, 제4 위치 정보가 수신되면, 상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인지 여부를 확인하는 단계 및 상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 상기 제2 문서 파일을 상기 제3 위치 정보와 대응시켜 상기 문서 파일 데이터베이스에 저장하는 단계를 더 포함할 수 있다.In addition, according to an embodiment of the present invention, the method of operating the document management service server may include receiving a second document file for a new electronic document created in the second user terminal from a second user terminal, and receiving the second document file. requesting transmission of current location information of the second user terminal to the second user terminal when a command to store a file is received; when third location information is received from the second user terminal, the second user terminal Checking a second IP address allocated to the user terminal, if the second IP address is confirmed, requesting the IP address location tracking service server to provide location information according to the second IP address, When fourth location information is received as location information according to the second IP address from the address location tracking service server, it is determined whether the separation distance between the third location information and the fourth location information is within the reference distance. and if it is confirmed that the separation distance between the third location information and the fourth location information is within the reference distance, storing the second document file in the document file database in correspondence with the third location information. may further include.
이상, 도 2를 참조하여 본 발명의 일실시예에 따른 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버의 동작 방법에 대해 설명하였다. 여기서, 본 발명의 일실시예에 따른 문서 관리 서비스 서버의 동작 방법은 도 1을 이용하여 설명한 문서 관리 서비스 서버(110)의 동작에 대한 구성과 대응될 수 있으므로, 이에 대한 보다 상세한 설명은 생략하기로 한다.In the above, a method of operating a document management service server for managing document files based on location information according to an embodiment of the present invention has been described with reference to FIG. 2 . Here, since the operation method of the document management service server according to an embodiment of the present invention may correspond to the configuration of the operation of the document
본 발명의 일실시예에 따른 문서 관리 서비스 서버의 동작 방법은 컴퓨터와의 결합을 통해 실행시키기 위한 저장매체에 저장된 컴퓨터 프로그램으로 구현될 수 있다.A method of operating a document management service server according to an embodiment of the present invention may be implemented as a computer program stored in a storage medium for execution through a combination with a computer.
또한, 본 발명의 일실시예에 따른 문서 관리 서비스 서버의 동작 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 매체에 기록되는 프로그램 명령은 본 발명을 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같.은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함한다. In addition, the operating method of the document management service server according to an embodiment of the present invention may be implemented in the form of program instructions that can be executed through various computer means and recorded in a computer readable medium. The computer readable medium may include program instructions, data files, data structures, etc. alone or in combination. Program instructions recorded on the medium may be those specially designed and configured for the present invention or those known and usable to those skilled in computer software. Examples of computer-readable recording media include magnetic media such as hard disks, floppy disks and magnetic tapes, optical media such as CD-ROMs and DVDs, and magnetic media such as floptical disks. - includes magneto-optical media, and hardware devices specially configured to store and execute program instructions, such as ROM, RAM, flash memory, etc. Examples of program instructions include high-level language codes that can be executed by a computer using an interpreter, as well as machine language codes such as those produced by a compiler.
이상과 같이 본 발명에서는 구체적인 구성 요소 등과 같은 특정 사항들과 한정된 실시예 및 도면에 의해 설명되었으나 이는 본 발명의 보다 전반적인 이해를 돕기 위해서 제공된 것일 뿐, 본 발명은 상기의 실시예에 한정되는 것은 아니며, 본 발명이 속하는 분야에서 통상적인 지식을 가진 자라면 이러한 기재로부터 다양한 수정 및 변형이 가능하다.As described above, the present invention has been described by specific details such as specific components and limited embodiments and drawings, but these are provided to help a more general understanding of the present invention, and the present invention is not limited to the above embodiments. , Those skilled in the art in the field to which the present invention belongs can make various modifications and variations from these descriptions.
따라서, 본 발명의 사상은 설명된 실시예에 국한되어 정해져서는 아니되며, 후술하는 특허청구범위뿐 아니라 이 특허청구범위와 균등하거나 등가적 변형이 있는 모든 것들은 본 발명 사상의 범주에 속한다고 할 것이다. Therefore, the spirit of the present invention should not be limited to the described embodiments, and it will be said that not only the claims to be described later, but also all modifications equivalent or equivalent to these claims belong to the scope of the present invention. .
110: 위치 정보를 기반으로 문서 파일을 관리하기 위한 문서 관리 서비스 서버
111: 문서 파일 데이터베이스
112: 제1 위치 정보 요청부
113: 문서 파일 검색부
114: 검색 결과 전송부
115: 제1 IP 주소 확인부
116: 제1 위치 정보 확인부
117: 문서 파일 전송부
118: 테이블 유지부
119: 암호화 이벤트 발생부
120: 일련번호 추출부
121: 연산 코드 생성부
122: 다항식 생성부
123: 암호화키 생성부
124: 암호화 전송부
125: 제2 위치 정보 요청부
126: 제2 IP 주소 확인부
127: 제2 위치 정보 확인부
128: 문서 파일 저장 처리부
131: 제1 사용자 단말
132: 제2 사용자 단말
140: IP 주소 위치 추적 서비스 서버110: document management service server for managing document files based on location information
111: document file database 112: first location information request unit
113: document file search unit 114: search result transmission unit
115: first IP address verification unit 116: first location information verification unit
117: document file transmission unit 118: table holding unit
119: encryption event generation unit 120: serial number extraction unit
121: operation code generator 122: polynomial generator
123: encryption key generation unit 124: encryption transmission unit
125: second location information request unit 126: second IP address verification unit
127: second location information confirmation unit 128: document file storage processing unit
131: first user terminal 132: second user terminal
140: IP address location tracking service server
Claims (12)
복수의 문서 파일들과, 상기 복수의 문서 파일들 각각이 생성된 지점의 위치 정보가 서로 대응되어 저장되어 있는 문서 파일 데이터베이스;
제1 사용자 단말로부터, 위치 정보 기반의 문서 파일 검색 요청이 수신되면, 상기 제1 사용자 단말로, 상기 제1 사용자 단말의 현재 위치 정보의 전송을 요청하는 제1 위치 정보 요청부;
상기 제1 사용자 단말로부터 제1 위치 정보가 수신되면, 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 사전 설정된 기준 반경 이내의 위치 정보를 갖는 문서 파일이 존재하는지 여부를 검색하는 문서 파일 검색부; 및
상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 상기 기준 반경 이내의 위치 정보를 갖는 문서 파일로, 적어도 하나의 문서 파일이 존재하는 것으로 검색되면, 상기 적어도 하나의 문서 파일 각각의 파일명으로 구성된 검색 결과 목록을 생성한 후, 상기 검색 결과 목록을, 상기 문서 파일 검색 요청에 대한 검색 결과로 지정하여 상기 제1 사용자 단말로 전송하는 검색 결과 전송부
를 포함하는 문서 관리 서비스 서버.A document management service server for managing document files based on location information,
a document file database in which a plurality of document files and location information of points where each of the plurality of document files is created are stored in correspondence with each other;
a first location information requesting unit requesting transmission of current location information of the first user terminal to the first user terminal when a location information-based document file search request is received from the first user terminal;
When first location information is received from the first user terminal, among the plurality of document files stored in the document file database, a document file having location information within a preset reference radius from the first location information exists. a document file search unit for searching whether or not; and
Among the plurality of document files stored in the document file database, if it is found that at least one document file exists among the document files having location information within the reference radius from the first location information, the at least one document file is found to exist. After creating a search result list composed of file names of each of the document files, the search result transmission unit designates the search result list as a search result for the document file search request and transmits the search result list to the first user terminal.
A document management service server comprising a.
상기 검색 결과 목록이 상기 제1 사용자 단말로 전송된 이후, 상기 제1 사용자 단말로부터, 상기 적어도 하나의 문서 파일 중 어느 하나인 제1 문서 파일에 대한 전송 요청이 수신되면, 상기 제1 사용자 단말에 할당되어 있는 제1 IP(Internet Protocol) 주소를 확인하는 제1 IP 주소 확인부;
상기 제1 IP 주소가 확인되면, 사전 설정된 IP 주소 위치 추적 서비스 서버로, 상기 제1 IP 주소에 따른 위치 정보의 제공을 요청하여, 상기 IP 주소 위치 추적 서비스 서버로부터, 상기 제1 IP 주소에 따른 위치 정보로, 제2 위치 정보가 수신되면, 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 사전 설정된 기준 거리 이내인지 여부를 확인하는 제1 위치 정보 확인부; 및
상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 상기 문서 파일 데이터베이스로부터 상기 제1 문서 파일을 추출하여 상기 제1 사용자 단말로 전송하는 문서 파일 전송부
를 더 포함하는 문서 관리 서비스 서버.According to claim 1,
After the search result list is transmitted to the first user terminal, when a transmission request for a first document file, which is any one of the at least one document file, is received from the first user terminal, the first user terminal a first IP address checking unit that checks an assigned first IP (Internet Protocol) address;
When the first IP address is identified, a request is made to a preset IP address location tracking service server to provide location information according to the first IP address, and from the IP address location tracking service server, location information according to the first IP address is requested. When second location information is received as location information, a first location information checking unit that checks whether a separation distance between the first location information and the second location information is within a predetermined reference distance; and
If it is confirmed that the separation distance between the first location information and the second location information is within the reference distance, the document file transmission unit extracts the first document file from the document file database and transmits it to the first user terminal.
A document management service server further comprising a.
상기 문서 파일 전송부는
상기 제1 사용자 단말과 사전 공유하고 있는 기준 위치 정보 테이블 - 상기 기준 위치 정보 테이블은, 사전 설정된 복수의 기준 위치 정보들과, 상기 복수의 기준 위치 정보들 각각에 대한 사전 할당된 k(k는 2 이상의 자연수임)자릿수의 일련번호가 기록된 테이블임 - 을 저장하여 유지하는 테이블 유지부;
상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가 상기 기준 거리 이내인 것으로 확인되면, 상기 문서 파일 데이터베이스로부터 상기 제1 문서 파일을 추출한 후, 상기 제1 문서 파일을 암호화하여 전송하기 위한 암호화 이벤트를 발생시키는 암호화 이벤트 발생부;
상기 암호화 이벤트가 발생되면, 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 제2 일련번호를 추출하는 일련번호 추출부;
상기 제1 일련번호와 상기 제2 일련번호가 추출되면, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로(modulo)-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제2 연산 코드를 생성하는 연산 코드 생성부;
상기 제1 연산 코드와 상기 제2 연산 코드가 생성되면, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제2 다항식을 생성하는 다항식 생성부;
상기 제1 다항식과 상기 제2 다항식이 생성되면, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 연산 다항식을 생성한 후, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 시드(seed) 코드를 생성한 후, 상기 시드 코드를 사전 설정된 암호화키 생성 함수에 입력으로 인가하여 제1 암호화키를 생성하는 암호화키 생성부; 및
상기 제1 암호화키가 생성되면, 상기 제1 문서 파일을 상기 제1 암호화키로 암호화함으로써 제1 암호화 파일을 생성한 후, 상기 제1 암호화 파일과 상기 암호화키 생성 함수를 상기 제1 사용자 단말로 전송하는 암호화 전송부
를 포함하고,
상기 제1 사용자 단말은
메모리 상에 상기 기준 위치 정보 테이블을 저장하고 있고, 상기 문서 관리 서비스 서버로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 제1 위치 정보를 기초로, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터 상기 제1 일련번호와 상기 제2 일련번호를 추출하여, 상기 제1 일련번호와 상기 제2 일련번호를 기초로 상기 시드 코드를 생성하고, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성한 후, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원하는 것을 특징으로 하는 문서 관리 서비스 서버.According to claim 2,
The document file transfer unit
Reference position information table previously shared with the first user terminal - The reference position information table includes a plurality of preset reference position information and a pre-allocated k for each of the plurality of reference position information (k is 2 a table holding unit that stores and maintains a table in which serial numbers of digits are recorded;
Encryption for encrypting and transmitting the first document file after extracting the first document file from the document file database when it is confirmed that the separation distance between the first location information and the second location information is within the reference distance. an encryption event generation unit generating an event;
When the encryption event occurs, first reference position information having a closest distance to the first position information among the plurality of reference position information is checked from the reference position information table, and the first reference position information for the first reference position information is determined. 1 A series of extracting a serial number, identifying second reference location information of the furthest distance from the first location information among the plurality of pieces of reference location information, and extracting a second serial number for the second reference location information. number extraction unit;
When the first serial number and the second serial number are extracted, the result value when a modulo-2 operation is performed on each of the k numbers constituting the first serial number is configured as a bit string. By doing so, a first operation code of k bits is generated, and a resultant value obtained when a modulo-2 operation is performed on each of the k numbers constituting the second serial number is configured as a bit string, thereby forming a second operation code of k bits. an operation code generation unit that generates an operation code;
When the first operation code and the second operation code are generated, the first polynomial is obtained by designating each coefficient of a binary polynomial having the highest order k-1 as k bit values constituting the first operation code. a polynomial generator for generating a second polynomial by designating each coefficient of a binary polynomial having a highest degree k-1 as k bit values constituting the second operation code;
When the first polynomial and the second polynomial are generated, the first polynomial and the second polynomial are multiplied to generate an operating polynomial that is a binary polynomial having a highest degree of 2k-2, and then each coefficient of the operating polynomial is generated. An encryption key generation unit generating a 2k-1 bit seed code by constructing a bit string and then applying the seed code as an input to a preset encryption key generation function to generate a first encryption key; and
When the first encryption key is generated, a first encryption file is generated by encrypting the first document file with the first encryption key, and then the first encryption file and the encryption key generation function are transmitted to the first user terminal. encryption transmission unit
including,
The first user terminal is
When the standard location information table is stored in a memory and the first encryption file and the encryption key generation function are received from the document management service server, they are stored in the memory based on the first location information The first serial number and the second serial number are extracted from the reference location information table, the seed code is generated based on the first serial number and the second serial number, and the seed code is converted into the encryption key. The document management service server of claim 1 , wherein the document management service server restores the first document file by applying an input to a generating function to generate the first encryption key and then decrypting the first encryption file with the first encryption key.
상기 제1 사용자 단말은
상기 문서 관리 서비스 서버로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 상기 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 상기 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 상기 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 상기 제2 일련번호를 추출한 후, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제2 연산 코드를 생성한 후, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제2 다항식을 생성한 후, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 상기 연산 다항식을 생성하고, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 상기 시드 코드를 생성한 후, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성하고, 상기 제1 암호화키가 생성되면, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원하는 것을 특징으로 하는 문서 관리 서비스 서버.According to claim 3,
The first user terminal is
When the first encryption file and the encryption key generating function are received from the document management service server, the first location information among the plurality of pieces of standard location information and the standard location information from the standard location information table stored in the memory. The first reference location information of the closest distance is identified, the first serial number for the first reference location information is extracted, and the first reference location information and the furthest distance from among the plurality of pieces of reference location information are identified. When the second reference location information is checked, the second serial number for the second reference location information is extracted, and then a modulo-2 operation is performed on each of the k numbers constituting the first serial number. The first operation code of k bits is generated by configuring the result value of as a bit string, and the result value when the modulo-2 operation is performed on each of the k numbers constituting the second serial number is bit. After generating the second operation code of k bits by configuring it as a column, each coefficient of a binary polynomial having the highest degree k-1 is designated as k bit values constituting the first operation code. After generating the 1 polynomial, generating the second polynomial by designating each coefficient of the binary polynomial having the highest degree k-1 as k bit values constituting the second operation code, the first polynomial and the second polynomial are multiplied together to generate the operation polynomial, which is a binary polynomial whose highest degree is 2k-2, and constructs each coefficient of the operation polynomial into a bit string to generate the seed code of 2k-1 bits. Then, the seed code is applied as an input to the encryption key generation function to generate the first encryption key, and when the first encryption key is generated, the first encryption file is decrypted with the first encryption key, 1 A document management service server characterized in restoring document files.
제2 사용자 단말로부터, 상기 제2 사용자 단말에서 작성된 신규 전자 문서에 대한 제2 문서 파일이 수신되면서, 상기 제2 문서 파일에 대한 저장 요청 명령이 수신되면, 상기 제2 사용자 단말로, 상기 제2 사용자 단말의 현재 위치 정보의 전송을 요청하는 제2 위치 정보 요청부;
상기 제2 사용자 단말로부터 제3 위치 정보가 수신되면, 상기 제2 사용자 단말에 할당되어 있는 제2 IP 주소를 확인하는 제2 IP 주소 확인부;
상기 제2 IP 주소가 확인되면, 상기 IP 주소 위치 추적 서비스 서버로, 상기 제2 IP 주소에 따른 위치 정보의 제공을 요청하여, 상기 IP 주소 위치 추적 서비스 서버로부터, 상기 제2 IP 주소에 따른 위치 정보로, 제4 위치 정보가 수신되면, 상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인지 여부를 확인하는 제2 위치 정보 확인부; 및
상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 상기 제2 문서 파일을 상기 제3 위치 정보와 대응시켜 상기 문서 파일 데이터베이스에 저장하는 문서 파일 저장 처리부
를 더 포함하는 문서 관리 서비스 서버.According to claim 2,
When a second document file for a new electronic document created in the second user terminal is received from the second user terminal and a storage request command for the second document file is received, to the second user terminal, the second document file is received. a second location information requesting unit requesting transmission of current location information of a user terminal;
a second IP address checking unit configured to check a second IP address assigned to the second user terminal when third location information is received from the second user terminal;
When the second IP address is identified, a request is made to the IP address location tracking service server to provide location information according to the second IP address, and the location according to the second IP address is requested from the IP address location tracking service server. a second location information checking unit that checks whether a separation distance between the third location information and the fourth location information is within the reference distance when the fourth location information is received as information; and
If it is determined that the separation distance between the third location information and the fourth location information is within the reference distance, the document file storage processing unit for storing the second document file in the document file database in correspondence with the third location information.
A document management service server further comprising a.
복수의 문서 파일들과, 상기 복수의 문서 파일들 각각이 생성된 지점의 위치 정보가 서로 대응되어 저장되어 있는 문서 파일 데이터베이스를 유지하는 단계;
제1 사용자 단말로부터, 위치 정보 기반의 문서 파일 검색 요청이 수신되면, 상기 제1 사용자 단말로, 상기 제1 사용자 단말의 현재 위치 정보의 전송을 요청하는 단계;
상기 제1 사용자 단말로부터 제1 위치 정보가 수신되면, 상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 사전 설정된 기준 반경 이내의 위치 정보를 갖는 문서 파일이 존재하는지 여부를 검색하는 단계; 및
상기 문서 파일 데이터베이스에 저장되어 있는 상기 복수의 문서 파일들 중, 상기 제1 위치 정보로부터 상기 기준 반경 이내의 위치 정보를 갖는 문서 파일로, 적어도 하나의 문서 파일이 존재하는 것으로 검색되면, 상기 적어도 하나의 문서 파일 각각의 파일명으로 구성된 검색 결과 목록을 생성한 후, 상기 검색 결과 목록을, 상기 문서 파일 검색 요청에 대한 검색 결과로 지정하여 상기 제1 사용자 단말로 전송하는 단계
를 포함하는 문서 관리 서비스 서버의 동작 방법.A method of operating a document management service server for managing document files based on location information,
maintaining a document file database in which a plurality of document files and location information of a point where each of the plurality of document files is created correspond to each other and are stored;
requesting transmission of current location information of the first user terminal to the first user terminal when a location information-based document file search request is received from the first user terminal;
When first location information is received from the first user terminal, among the plurality of document files stored in the document file database, a document file having location information within a preset reference radius from the first location information exists. Searching whether or not; and
Among the plurality of document files stored in the document file database, if it is found that at least one document file exists among the document files having location information within the reference radius from the first location information, the at least one document file is found to exist. After generating a search result list composed of file names of each document file, designating the search result list as a search result for the document file search request and transmitting the search result list to the first user terminal.
A method of operating a document management service server comprising a.
상기 검색 결과 목록이 상기 제1 사용자 단말로 전송된 이후, 상기 제1 사용자 단말로부터, 상기 적어도 하나의 문서 파일 중 어느 하나인 제1 문서 파일에 대한 전송 요청이 수신되면, 상기 제1 사용자 단말에 할당되어 있는 제1 IP(Internet Protocol) 주소를 확인하는 단계;
상기 제1 IP 주소가 확인되면, 사전 설정된 IP 주소 위치 추적 서비스 서버로, 상기 제1 IP 주소에 따른 위치 정보의 제공을 요청하여, 상기 IP 주소 위치 추적 서비스 서버로부터, 상기 제1 IP 주소에 따른 위치 정보로, 제2 위치 정보가 수신되면, 상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 사전 설정된 기준 거리 이내인지 여부를 확인하는 단계; 및
상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 상기 문서 파일 데이터베이스로부터 상기 제1 문서 파일을 추출하여 상기 제1 사용자 단말로 전송하는 단계
를 더 포함하는 문서 관리 서비스 서버의 동작 방법.According to claim 6,
After the search result list is transmitted to the first user terminal, when a transmission request for a first document file, which is any one of the at least one document file, is received from the first user terminal, the first user terminal Checking the assigned first IP (Internet Protocol) address;
When the first IP address is identified, a request is made to a preset IP address location tracking service server to provide location information according to the first IP address, and from the IP address location tracking service server, location information according to the first IP address is requested. When second location information is received as location information, checking whether a distance between the first location information and the second location information is within a predetermined reference distance; and
extracting the first document file from the document file database and transmitting the same to the first user terminal when it is confirmed that the separation distance between the first location information and the second location information is within the reference distance;
Method of operating a document management service server further comprising a.
상기 제1 문서 파일을 추출하여 상기 제1 사용자 단말로 전송하는 단계는
상기 제1 사용자 단말과 사전 공유하고 있는 기준 위치 정보 테이블 - 상기 기준 위치 정보 테이블은, 사전 설정된 복수의 기준 위치 정보들과, 상기 복수의 기준 위치 정보들 각각에 대한 사전 할당된 k(k는 2 이상의 자연수임)자릿수의 일련번호가 기록된 테이블임 - 을 저장하여 유지하는 단계;
상기 제1 위치 정보와 상기 제2 위치 정보 간의 이격 거리가 상기 기준 거리 이내인 것으로 확인되면, 상기 문서 파일 데이터베이스로부터 상기 제1 문서 파일을 추출한 후, 상기 제1 문서 파일을 암호화하여 전송하기 위한 암호화 이벤트를 발생시키는 단계;
상기 암호화 이벤트가 발생되면, 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 제2 일련번호를 추출하는 단계;
상기 제1 일련번호와 상기 제2 일련번호가 추출되면, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로(modulo)-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 제2 연산 코드를 생성하는 단계;
상기 제1 연산 코드와 상기 제2 연산 코드가 생성되면, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 제2 다항식을 생성하는 단계;
상기 제1 다항식과 상기 제2 다항식이 생성되면, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 연산 다항식을 생성한 후, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 시드(seed) 코드를 생성한 후, 상기 시드 코드를 사전 설정된 암호화키 생성 함수에 입력으로 인가하여 제1 암호화키를 생성하는 단계; 및
상기 제1 암호화키가 생성되면, 상기 제1 문서 파일을 상기 제1 암호화키로 암호화함으로써 제1 암호화 파일을 생성한 후, 상기 제1 암호화 파일과 상기 암호화키 생성 함수를 상기 제1 사용자 단말로 전송하는 단계
를 포함하고,
상기 제1 사용자 단말은
메모리 상에 상기 기준 위치 정보 테이블을 저장하고 있고, 상기 문서 관리 서비스 서버로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 제1 위치 정보를 기초로, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터 상기 제1 일련번호와 상기 제2 일련번호를 추출하여, 상기 제1 일련번호와 상기 제2 일련번호를 기초로 상기 시드 코드를 생성하고, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성한 후, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원하는 것을 특징으로 하는 문서 관리 서비스 서버의 동작 방법.According to claim 7,
The step of extracting the first document file and transmitting it to the first user terminal
Reference position information table previously shared with the first user terminal - The reference position information table includes a plurality of preset reference position information and a pre-allocated k for each of the plurality of reference position information (k is 2 storing and maintaining a table in which serial numbers of digits are recorded;
Encryption for encrypting and transmitting the first document file after extracting the first document file from the document file database when it is confirmed that the separation distance between the first location information and the second location information is within the reference distance. generating an event;
When the encryption event occurs, first reference position information having a closest distance to the first position information among the plurality of reference position information is checked from the reference position information table, and the first reference position information for the first reference position information is determined. 1 Extracting a serial number, identifying second reference location information that is furthest from the first location information among the plurality of pieces of reference location information, and extracting a second serial number for the second reference location information. ;
When the first serial number and the second serial number are extracted, the result value when a modulo-2 operation is performed on each of the k numbers constituting the first serial number is configured as a bit string. By doing so, a first operation code of k bits is generated, and a resultant value obtained when a modulo-2 operation is performed on each of the k numbers constituting the second serial number is configured as a bit string, thereby forming a second operation code of k bits. generating an opcode;
When the first operation code and the second operation code are generated, the first polynomial is obtained by designating each coefficient of a binary polynomial having the highest order k-1 as k bit values constituting the first operation code. generating a second polynomial by specifying each coefficient of a binary polynomial having a highest degree k-1 as k bit values constituting the second operation code;
When the first polynomial and the second polynomial are generated, the first polynomial and the second polynomial are multiplied to generate an operating polynomial that is a binary polynomial having a highest degree of 2k-2, and then each coefficient of the operating polynomial is generated. generating a 2k-1 bit seed code by constructing a bit string, and then generating a first encryption key by applying the seed code as an input to a preset encryption key generation function; and
When the first encryption key is generated, a first encryption file is generated by encrypting the first document file with the first encryption key, and then the first encryption file and the encryption key generation function are transmitted to the first user terminal. step to do
including,
The first user terminal is
When the standard location information table is stored in a memory and the first encryption file and the encryption key generation function are received from the document management service server, they are stored in the memory based on the first location information The first serial number and the second serial number are extracted from the reference location information table, the seed code is generated based on the first serial number and the second serial number, and the seed code is converted into the encryption key. A method of operating a document management service server, characterized in that the document management service server restores the first document file by generating the first encryption key by applying an input to a generating function and then decrypting the first encryption file with the first encryption key. .
상기 제1 사용자 단말은
상기 문서 관리 서비스 서버로부터, 상기 제1 암호화 파일과 상기 암호화키 생성 함수가 수신되면, 상기 메모리 상에 저장되어 있는 상기 기준 위치 정보 테이블로부터, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 가까운 거리의 상기 제1 기준 위치 정보를 확인하여, 상기 제1 기준 위치 정보에 대한 상기 제1 일련번호를 추출하고, 상기 복수의 기준 위치 정보들 중 상기 제1 위치 정보와 가장 먼 거리의 상기 제2 기준 위치 정보를 확인하여, 상기 제2 기준 위치 정보에 대한 상기 제2 일련번호를 추출한 후, 상기 제1 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제1 연산 코드를 생성하고, 상기 제2 일련번호를 구성하는 k개의 숫자들 각각에 대해 모듈로-2 연산을 수행하였을 때의 결과 값을 비트열로 구성함으로써 k비트의 상기 제2 연산 코드를 생성한 후, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제1 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제1 다항식을 생성하고, 최고차수가 k-1인 2진 다항식의 각 계수를, 상기 제2 연산 코드를 구성하는 k개의 비트값들로 지정함으로써 상기 제2 다항식을 생성한 후, 상기 제1 다항식과 상기 제2 다항식을 서로 곱하여 최고차수가 2k-2가 되는 2진 다항식인 상기 연산 다항식을 생성하고, 상기 연산 다항식의 각 계수를 비트열로 구성함으로써 2k-1비트의 상기 시드 코드를 생성한 후, 상기 시드 코드를 상기 암호화키 생성 함수에 입력으로 인가하여 상기 제1 암호화키를 생성하고, 상기 제1 암호화키가 생성되면, 상기 제1 암호화키로 상기 제1 암호화 파일을 복호화함으로써, 상기 제1 문서 파일을 복원하는 것을 특징으로 하는 문서 관리 서비스 서버의 동작 방법.According to claim 8,
The first user terminal is
When the first encryption file and the encryption key generating function are received from the document management service server, the first location information among the plurality of pieces of standard location information and the standard location information from the standard location information table stored in the memory. The first reference location information of the closest distance is identified, the first serial number for the first reference location information is extracted, and the first reference location information and the furthest distance from among the plurality of pieces of reference location information are identified. When the second reference location information is checked, the second serial number for the second reference location information is extracted, and then a modulo-2 operation is performed on each of the k numbers constituting the first serial number. The first operation code of k bits is generated by configuring the result value of as a bit string, and the result value when the modulo-2 operation is performed on each of the k numbers constituting the second serial number is bit. After generating the second operation code of k bits by configuring it as a column, each coefficient of a binary polynomial having the highest degree k-1 is designated as k bit values constituting the first operation code. After generating the 1 polynomial, generating the second polynomial by designating each coefficient of the binary polynomial having the highest degree k-1 as k bit values constituting the second operation code, the first polynomial and the second polynomial are multiplied together to generate the operation polynomial, which is a binary polynomial whose highest degree is 2k-2, and constructs each coefficient of the operation polynomial into a bit string to generate the seed code of 2k-1 bits. Then, the seed code is applied as an input to the encryption key generation function to generate the first encryption key, and when the first encryption key is generated, the first encryption file is decrypted with the first encryption key, 1 A method of operating a document management service server characterized by restoring a document file.
제2 사용자 단말로부터, 상기 제2 사용자 단말에서 작성된 신규 전자 문서에 대한 제2 문서 파일이 수신되면서, 상기 제2 문서 파일에 대한 저장 요청 명령이 수신되면, 상기 제2 사용자 단말로, 상기 제2 사용자 단말의 현재 위치 정보의 전송을 요청하는 단계;
상기 제2 사용자 단말로부터 제3 위치 정보가 수신되면, 상기 제2 사용자 단말에 할당되어 있는 제2 IP 주소를 확인하는 단계;
상기 제2 IP 주소가 확인되면, 상기 IP 주소 위치 추적 서비스 서버로, 상기 제2 IP 주소에 따른 위치 정보의 제공을 요청하여, 상기 IP 주소 위치 추적 서비스 서버로부터, 상기 제2 IP 주소에 따른 위치 정보로, 제4 위치 정보가 수신되면, 상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인지 여부를 확인하는 단계; 및
상기 제3 위치 정보와 상기 제4 위치 정보 간의 이격 거리가, 상기 기준 거리 이내인 것으로 확인되면, 상기 제2 문서 파일을 상기 제3 위치 정보와 대응시켜 상기 문서 파일 데이터베이스에 저장하는 단계
를 더 포함하는 문서 관리 서비스 서버의 동작 방법.According to claim 7,
When a second document file for a new electronic document created in the second user terminal is received from the second user terminal and a storage request command for the second document file is received, to the second user terminal, the second document file is received. requesting transmission of current location information of a user terminal;
checking a second IP address assigned to the second user terminal when third location information is received from the second user terminal;
When the second IP address is identified, a request is made to the IP address location tracking service server to provide location information according to the second IP address, and the location according to the second IP address is requested from the IP address location tracking service server. When fourth location information is received as information, checking whether a separation distance between the third location information and the fourth location information is within the reference distance; and
If it is determined that the separation distance between the third location information and the fourth location information is within the reference distance, storing the second document file in the document file database in correspondence with the third location information.
Method of operating a document management service server further comprising a.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020220021220A KR102694766B1 (en) | 2022-02-18 | 2022-02-18 | Document management service server for managing document files based on location information, and the operating method thereof |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020220021220A KR102694766B1 (en) | 2022-02-18 | 2022-02-18 | Document management service server for managing document files based on location information, and the operating method thereof |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20230124206A true KR20230124206A (en) | 2023-08-25 |
KR102694766B1 KR102694766B1 (en) | 2024-08-13 |
Family
ID=87847172
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020220021220A KR102694766B1 (en) | 2022-02-18 | 2022-02-18 | Document management service server for managing document files based on location information, and the operating method thereof |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR102694766B1 (en) |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2009134463A (en) * | 2007-11-29 | 2009-06-18 | Nippon Telegr & Teleph Corp <Ntt> | Retrieval device, retrieval method and retrieval program for document group including geographic information, and recording medium recording the program |
KR20120063178A (en) * | 2010-12-07 | 2012-06-15 | 주식회사 씽크풀 | System and method for service security based on location |
KR20210065809A (en) * | 2019-11-27 | 2021-06-04 | 주식회사 한컴위드 | Protocol management server to support zero knowledge-snarks based proof services and operating method thereof |
-
2022
- 2022-02-18 KR KR1020220021220A patent/KR102694766B1/en active IP Right Grant
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2009134463A (en) * | 2007-11-29 | 2009-06-18 | Nippon Telegr & Teleph Corp <Ntt> | Retrieval device, retrieval method and retrieval program for document group including geographic information, and recording medium recording the program |
KR20120063178A (en) * | 2010-12-07 | 2012-06-15 | 주식회사 씽크풀 | System and method for service security based on location |
KR20210065809A (en) * | 2019-11-27 | 2021-06-04 | 주식회사 한컴위드 | Protocol management server to support zero knowledge-snarks based proof services and operating method thereof |
Also Published As
Publication number | Publication date |
---|---|
KR102694766B1 (en) | 2024-08-13 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10063528B2 (en) | Searchable encryption enabling encrypted search based on document type | |
US20080071824A1 (en) | Record relationship processing | |
Awad et al. | Chaotic searchable encryption for mobile cloud storage | |
US8510860B2 (en) | Local storage of information pedigrees | |
US20160125198A1 (en) | Searchable encryption with secure and efficient updates | |
US7152693B2 (en) | Password security utility | |
JP5307199B2 (en) | Data management system and data management method | |
US20230144072A1 (en) | Data storage server and client devices for securely storing data | |
US11442922B2 (en) | Data management method, data management apparatus, and non-transitory computer readable medium | |
JP2006189925A (en) | Private information management system, private information management program, and private information protection method | |
JP2014528680A (en) | Method, system and apparatus for digital content transmission | |
US20090259658A1 (en) | Apparatus and method for storing and retrieving files | |
KR20230124206A (en) | Document management service server for managing document files based on location information, and the operating method thereof | |
US11106740B2 (en) | Search device, search system, search method, and computer readable medium | |
KR20230124207A (en) | Document sharing service server for managing document sharing service based on cloud, and the operating method thereof | |
CN114661793A (en) | Fuzzy query method and device, electronic equipment and storage medium | |
JP2003296331A (en) | Data retrieval method and system, retrieval keyword generation device and its computer program | |
JP2022511580A (en) | Systems and methods for protecting data | |
KR102503471B1 (en) | Service server capable of performing internet access management services according to grades and the operating method thereof | |
KR102526406B1 (en) | Access management system apparatus which manages access to the original contents data, which is to be a subject to an nft, and the operating method thereof | |
KR102613911B1 (en) | Electronic terminal apparatus capable of preventing access to url addresses of harmful sites inserted as hyperlinks in document files and operating method thereof | |
KR102658134B1 (en) | Electronic document management server that performs database processing for electronic document based on identification tag and operating method thereof | |
WO2014114987A1 (en) | Personal device encryption | |
KR102532655B1 (en) | Internet access management service server that can manage internet access for electronic terminals through setting of scheduling rules for internet use restriction and the operating method thereof | |
CN115098837B (en) | Data processing method and device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant |