Get HTML meta data by Ruby library

Updated:
Categories: programming
Tags: #Ruby #Script

HTML meta 데이터 가져오는 Ruby 스크립트 만들기

URL으로 HTML meta 데이터를 가져와 보여주는 Jekyll Plugin을 만들고 싶어서, 해당 기능을 가지고 있는 Ruby 라이브러리들을 찾아봄. URL을 입력값으로 meta 데이터를 객체로 매핑해서 반환해주는 것이 요구사항임.

Plugin을 만들기 전 라이브러리들을 테스트해봄. 우선, 아래와 같이 라이브러리를 다운로드하고, 실행.

# Install ruby gem
$ gem install {target gem name}

# Execute script 
$ ruby {target script name}.rb

스크립트들은 각 Github에 있는 예제를 참고하여 아래와 같이 작성.

open_graph_reader

ogp

metainspector

위의 두개는 제대로 데이터를 가져오는 사이트가 있고, 못 가져오는 사이트가 있었음. 이 라이브러리는 테스트한 URL들은 정상적으로 가져옴.

  • 결과
    $ ruby metainspector_script.rb
    {"name"=>{"description"=>["OverviewSwift3 의 Alamofire 라이브러리를 사용하여 callback 함수로 API request를 구현.하지만, callback 함수 부분이 가독성이 떨어지는 것 같아 코드를 리팩토링해보기로 결정.AngularJS에서 defer 객체를 통한 Promise와 Scala의 Future, Promise 등과 같이 익숙한 형태를 찾아봄.Swift에서 Promise 패턴을 사용할 수 있는 라이브러리인 PromiseKit과 Alamofire을 확장한 PromiseKit+Alamofire을 발견하고 사용."], "author"=>["Jungbin Kim"], "handheldfriendly"=>["True"], "mobileoptimized"=>["320"], "viewport"=>["width=device-width, initial-scale=1.0"]}, "http-equiv"=>{}, "property"=>{"og:locale"=>["en_US"], "og:site_name"=>["Jungbin's Blog"], "og:title"=>["Swift3(PromiseKit)으로 Async 사용해보기"], "og:description"=>["OverviewSwift3 의 Alamofire 라이브러리를 사용하여 callback 함수로 API request를 구현.하지만, callback 함수 부분이 가독성이 떨어지는 것 같아 코드를 리팩토링해보기로 결정.AngularJS에서 defer 객체를 통한 Promise와 Scala의 Future, Promise 등과 같이 익숙한 형태를 찾아봄.Swift에서 Promise 패턴을 사용할 수 있는 라이브러리인 PromiseKit과 Alamofire을 확장한 PromiseKit+Alamofire을 발견하고 사용."], "og:type"=>["article"], "article:published_time"=>["2018-03-04T10:01:45+00:00"]}, "charset"=>["utf-8"]}
    

Comments