Go to file
Kanezoh cb53c7eab7 fix indent 2021-11-18 12:10:07 +09:00
.github/workflows fix indent 2021-11-18 12:10:07 +09:00
spec MechanizeCr -> Mechanize 2021-11-16 10:50:34 +02:00
src add comment to other classes 2021-11-18 11:45:30 +09:00
.editorconfig First Commit 2021-04-19 13:50:12 +09:00
.gitignore First Commit 2021-04-19 13:50:12 +09:00
.travis.yml First Commit 2021-04-19 13:50:12 +09:00
LICENSE First Commit 2021-04-19 13:50:12 +09:00
README.md add contributor 2021-08-24 11:50:39 +09:00
main.cr format code 2021-08-17 19:30:01 +03:00
shard.yml switch to Lexbor parser 2021-08-14 12:20:15 +03:00

README.md

mechanize.cr

Crystal CI

This project is inspired by Ruby's mechanize. The purpose is to cover all the features of original one. Now, mechanize.cr can automatically store and send cookies, fill and submit forms.

Installation

  1. Add the dependency to your shard.yml:

    dependencies:
      mechanize:
        github: Kanezoh/mechanize.cr
    
  2. Run shards install

Usage

simple GET request

require "mechanize"

agent = Mechanize.new
page = agent.get("http://example.com/")

puts page.code # => 200
puts page.body # => html
puts page.title # => Example Domain

POST request

You can also send post request with data.

require "mechanize"

agent = Mechanize.new
query = {"foo" => "foo_value", "bar" => "bar_value"}
page = agent.post("http://example.com/", query: query)
# => request body is foo=foo_value&bar=bar_value

add query params, request_headers

You can add any query parameters and headers to requests.

require "mechanize"

agent = Mechanize.new
agent.request_headers = HTTP::Headers{"Foo" => "Bar"}
params = {"hoge" => "hoge"}
page = agent.get("http://example.com/", params: params)
# The actual URL is http://example.com/?hoge=hoge

fill and submit form

You can fill and submit form by using field_with and submit. It enables you to scrape web pages requiring login.

require "mechanize"

agent = Mechanize.new
page = agent.get("#{web page contains login form}")
form = page.forms[0]
form.field_with("email").value = "tester@example.com"
form.field_with("password").value = "xxxxxx"
agent.submit(form)

agent.get("#{web page only logged-in users can see}"

search node

You can use css selector to search html nodes by using #css method. This method is from lexbor, so if you want to explore more, please refer the repository.

puts page.css("h1").first.inner_text

Contributing

  1. Fork it (https://github.com/Kanezoh/mechanize.cr/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors