spider_rails 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. checksums.yaml +7 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README.rdoc +3 -0
  4. data/Rakefile +32 -0
  5. data/lib/spider_rails.rb +4 -0
  6. data/lib/spider_rails/bilibili.rb +68 -0
  7. data/lib/spider_rails/common.rb +62 -0
  8. data/lib/spider_rails/google_dict.rb +91 -0
  9. data/lib/spider_rails/hl.rb +13 -0
  10. data/lib/spider_rails/ji_ying.rb +61 -0
  11. data/lib/spider_rails/sample_data.rb +10 -0
  12. data/lib/spider_rails/spread_sheet.rb +32 -0
  13. data/lib/spider_rails/version.rb +3 -0
  14. data/test/dummy/README.rdoc +28 -0
  15. data/test/dummy/Rakefile +6 -0
  16. data/test/dummy/app/assets/javascripts/anis.js +2 -0
  17. data/test/dummy/app/assets/javascripts/application.js +13 -0
  18. data/test/dummy/app/assets/stylesheets/anis.css +4 -0
  19. data/test/dummy/app/assets/stylesheets/application.css +13 -0
  20. data/test/dummy/app/assets/stylesheets/scaffold.css +56 -0
  21. data/test/dummy/app/controllers/anis_controller.rb +58 -0
  22. data/test/dummy/app/controllers/application_controller.rb +5 -0
  23. data/test/dummy/app/helpers/anis_helper.rb +2 -0
  24. data/test/dummy/app/helpers/application_helper.rb +2 -0
  25. data/test/dummy/app/models/ani.rb +2 -0
  26. data/test/dummy/app/views/anis/_form.html.erb +25 -0
  27. data/test/dummy/app/views/anis/edit.html.erb +6 -0
  28. data/test/dummy/app/views/anis/index.html.erb +29 -0
  29. data/test/dummy/app/views/anis/new.html.erb +5 -0
  30. data/test/dummy/app/views/anis/show.html.erb +14 -0
  31. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  32. data/test/dummy/bin/bundle +3 -0
  33. data/test/dummy/bin/rails +4 -0
  34. data/test/dummy/bin/rake +4 -0
  35. data/test/dummy/config.ru +4 -0
  36. data/test/dummy/config/application.rb +23 -0
  37. data/test/dummy/config/boot.rb +5 -0
  38. data/test/dummy/config/database.yml +25 -0
  39. data/test/dummy/config/environment.rb +5 -0
  40. data/test/dummy/config/environments/development.rb +29 -0
  41. data/test/dummy/config/environments/production.rb +80 -0
  42. data/test/dummy/config/environments/test.rb +36 -0
  43. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  44. data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  45. data/test/dummy/config/initializers/inflections.rb +16 -0
  46. data/test/dummy/config/initializers/mime_types.rb +5 -0
  47. data/test/dummy/config/initializers/secret_token.rb +12 -0
  48. data/test/dummy/config/initializers/session_store.rb +3 -0
  49. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  50. data/test/dummy/config/locales/en.yml +23 -0
  51. data/test/dummy/config/routes.rb +56 -0
  52. data/test/dummy/db/development.sqlite3 +0 -0
  53. data/test/dummy/db/migrate/20130714091905_create_anis.rb +10 -0
  54. data/test/dummy/db/schema.rb +23 -0
  55. data/test/dummy/db/test.sqlite3 +0 -0
  56. data/test/dummy/log/development.log +21 -0
  57. data/test/dummy/log/test.log +160 -0
  58. data/test/dummy/public/404.html +58 -0
  59. data/test/dummy/public/422.html +58 -0
  60. data/test/dummy/public/500.html +57 -0
  61. data/test/dummy/public/favicon.ico +0 -0
  62. data/test/dummy/tmp/pids/server.pid +1 -0
  63. data/test/ji_ying_test.rb +58 -0
  64. data/test/libpeerconnection.log +0 -0
  65. data/test/spider_rails_test.rb +7 -0
  66. data/test/test_helper.rb +18 -0
  67. metadata +189 -0
@@ -0,0 +1,36 @@
1
+ Dummy::Application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb.
3
+
4
+ # The test environment is used exclusively to run your application's
5
+ # test suite. You never need to work with it otherwise. Remember that
6
+ # your test database is "scratch space" for the test suite and is wiped
7
+ # and recreated between test runs. Don't rely on the data there!
8
+ config.cache_classes = true
9
+
10
+ # Do not eager load code on boot. This avoids loading your whole application
11
+ # just for the purpose of running a single test. If you are using a tool that
12
+ # preloads Rails for running tests, you may have to set it to true.
13
+ config.eager_load = false
14
+
15
+ # Configure static asset server for tests with Cache-Control for performance.
16
+ config.serve_static_assets = true
17
+ config.static_cache_control = "public, max-age=3600"
18
+
19
+ # Show full error reports and disable caching.
20
+ config.consider_all_requests_local = true
21
+ config.action_controller.perform_caching = false
22
+
23
+ # Raise exceptions instead of rendering exception templates.
24
+ config.action_dispatch.show_exceptions = false
25
+
26
+ # Disable request forgery protection in test environment.
27
+ config.action_controller.allow_forgery_protection = false
28
+
29
+ # Tell Action Mailer not to deliver emails to the real world.
30
+ # The :test delivery method accumulates sent emails in the
31
+ # ActionMailer::Base.deliveries array.
32
+ config.action_mailer.delivery_method = :test
33
+
34
+ # Print deprecation notices to the stderr.
35
+ config.active_support.deprecation = :stderr
36
+ end
@@ -0,0 +1,7 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4
+ # Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
5
+
6
+ # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
7
+ # Rails.backtrace_cleaner.remove_silencers!
@@ -0,0 +1,4 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Configure sensitive parameters which will be filtered from the log file.
4
+ Rails.application.config.filter_parameters += [:password]
@@ -0,0 +1,16 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new inflection rules using the following format. Inflections
4
+ # are locale specific, and you may define rules for as many different
5
+ # locales as you wish. All of these examples are active by default:
6
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
7
+ # inflect.plural /^(ox)$/i, '\1en'
8
+ # inflect.singular /^(ox)en/i, '\1'
9
+ # inflect.irregular 'person', 'people'
10
+ # inflect.uncountable %w( fish sheep )
11
+ # end
12
+
13
+ # These inflection rules are supported but not enabled by default:
14
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
15
+ # inflect.acronym 'RESTful'
16
+ # end
@@ -0,0 +1,5 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new mime types for use in respond_to blocks:
4
+ # Mime::Type.register "text/richtext", :rtf
5
+ # Mime::Type.register_alias "text/html", :iphone
@@ -0,0 +1,12 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Your secret key is used for verifying the integrity of signed cookies.
4
+ # If you change this key, all old signed cookies will become invalid!
5
+
6
+ # Make sure the secret is at least 30 characters and all random,
7
+ # no regular words or you'll be exposed to dictionary attacks.
8
+ # You can use `rake secret` to generate a secure secret key.
9
+
10
+ # Make sure your secret_key_base is kept private
11
+ # if you're sharing your code publicly.
12
+ Dummy::Application.config.secret_key_base = '398fd8e3d0d908f6a14be34690e4a534b02336e0340697d8344a70583419c0cb76d8564d025d96cfa86cb8800e1288a9f8a07d561b6d2a60c6cc8a1f1ff39f41'
@@ -0,0 +1,3 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ Dummy::Application.config.session_store :cookie_store, key: '_dummy_session'
@@ -0,0 +1,14 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # This file contains settings for ActionController::ParamsWrapper which
4
+ # is enabled by default.
5
+
6
+ # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7
+ ActiveSupport.on_load(:action_controller) do
8
+ wrap_parameters format: [:json] if respond_to?(:wrap_parameters)
9
+ end
10
+
11
+ # To enable root element in JSON for ActiveRecord objects.
12
+ # ActiveSupport.on_load(:active_record) do
13
+ # self.include_root_in_json = true
14
+ # end
@@ -0,0 +1,23 @@
1
+ # Files in the config/locales directory are used for internationalization
2
+ # and are automatically loaded by Rails. If you want to use locales other
3
+ # than English, add the necessary files in this directory.
4
+ #
5
+ # To use the locales, use `I18n.t`:
6
+ #
7
+ # I18n.t 'hello'
8
+ #
9
+ # In views, this is aliased to just `t`:
10
+ #
11
+ # <%= t('hello') %>
12
+ #
13
+ # To use a different locale, set it with `I18n.locale`:
14
+ #
15
+ # I18n.locale = :es
16
+ #
17
+ # This would use the information in config/locales/es.yml.
18
+ #
19
+ # To learn more, please read the Rails Internationalization guide
20
+ # available at http://guides.rubyonrails.org/i18n.html.
21
+
22
+ en:
23
+ hello: "Hello world"
@@ -0,0 +1,56 @@
1
+ Dummy::Application.routes.draw do
2
+ # The priority is based upon order of creation: first created -> highest priority.
3
+ # See how all your routes lay out with "rake routes".
4
+
5
+ # You can have the root of your site routed with "root"
6
+ # root 'welcome#index'
7
+
8
+ # Example of regular route:
9
+ # get 'products/:id' => 'catalog#view'
10
+
11
+ # Example of named route that can be invoked with purchase_url(id: product.id)
12
+ # get 'products/:id/purchase' => 'catalog#purchase', as: :purchase
13
+
14
+ # Example resource route (maps HTTP verbs to controller actions automatically):
15
+ # resources :products
16
+
17
+ # Example resource route with options:
18
+ # resources :products do
19
+ # member do
20
+ # get 'short'
21
+ # post 'toggle'
22
+ # end
23
+ #
24
+ # collection do
25
+ # get 'sold'
26
+ # end
27
+ # end
28
+
29
+ # Example resource route with sub-resources:
30
+ # resources :products do
31
+ # resources :comments, :sales
32
+ # resource :seller
33
+ # end
34
+
35
+ # Example resource route with more complex sub-resources:
36
+ # resources :products do
37
+ # resources :comments
38
+ # resources :sales do
39
+ # get 'recent', on: :collection
40
+ # end
41
+ # end
42
+
43
+ # Example resource route with concerns:
44
+ # concern :toggleable do
45
+ # post 'toggle'
46
+ # end
47
+ # resources :posts, concerns: :toggleable
48
+ # resources :photos, concerns: :toggleable
49
+
50
+ # Example resource route within a namespace:
51
+ # namespace :admin do
52
+ # # Directs /admin/products/* to Admin::ProductsController
53
+ # # (app/controllers/admin/products_controller.rb)
54
+ # resources :products
55
+ # end
56
+ end
Binary file
@@ -0,0 +1,10 @@
1
+ class CreateAnis < ActiveRecord::Migration
2
+ def change
3
+ create_table :anis do |t|
4
+ t.string :title
5
+ t.string :torrent
6
+
7
+ t.timestamps
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,23 @@
1
+ # encoding: UTF-8
2
+ # This file is auto-generated from the current state of the database. Instead
3
+ # of editing this file, please use the migrations feature of Active Record to
4
+ # incrementally modify your database, and then regenerate this schema definition.
5
+ #
6
+ # Note that this schema.rb definition is the authoritative source for your
7
+ # database schema. If you need to create the application database on another
8
+ # system, you should be using db:schema:load, not running all the migrations
9
+ # from scratch. The latter is a flawed and unsustainable approach (the more migrations
10
+ # you'll amass, the slower it'll run and the greater likelihood for issues).
11
+ #
12
+ # It's strongly recommended that you check this file into your version control system.
13
+
14
+ ActiveRecord::Schema.define(version: 20130714091905) do
15
+
16
+ create_table "anis", force: true do |t|
17
+ t.string "title"
18
+ t.string "torrent"
19
+ t.datetime "created_at"
20
+ t.datetime "updated_at"
21
+ end
22
+
23
+ end
Binary file
@@ -0,0 +1,21 @@
1
+  (30.8ms) CREATE TABLE "schema_migrations" ("version" varchar(255) NOT NULL) 
2
+  (10.7ms) CREATE UNIQUE INDEX "unique_schema_migrations" ON "schema_migrations" ("version")
3
+ ActiveRecord::SchemaMigration Load (0.2ms) SELECT "schema_migrations".* FROM "schema_migrations"
4
+ Migrating to CreateAnis (20130714091905)
5
+  (0.2ms) begin transaction
6
+  (0.9ms) CREATE TABLE "anis" ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "title" varchar(255), "torrent" varchar(255), "created_at" datetime, "updated_at" datetime) 
7
+ SQL (0.5ms) INSERT INTO "schema_migrations" ("version") VALUES (?) [["version", "20130714091905"]]
8
+  (27.5ms) commit transaction
9
+ ActiveRecord::SchemaMigration Load (0.1ms) SELECT "schema_migrations".* FROM "schema_migrations"
10
+  (18.1ms) CREATE TABLE "anis" ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "title" varchar(255), "torrent" varchar(255), "created_at" datetime, "updated_at" datetime) 
11
+  (24.8ms) CREATE TABLE "schema_migrations" ("version" varchar(255) NOT NULL)
12
+  (28.8ms) CREATE UNIQUE INDEX "unique_schema_migrations" ON "schema_migrations" ("version")
13
+  (0.4ms) SELECT version FROM "schema_migrations"
14
+  (10.3ms) INSERT INTO "schema_migrations" (version) VALUES ('20130714091905')
15
+ ActiveRecord::SchemaMigration Load (0.1ms) SELECT "schema_migrations".* FROM "schema_migrations"
16
+ ActiveRecord::SchemaMigration Load (0.1ms) SELECT "schema_migrations".* FROM "schema_migrations"
17
+  (19.6ms) CREATE TABLE "anis" ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "title" varchar(255), "torrent" varchar(255), "created_at" datetime, "updated_at" datetime) 
18
+  (26.9ms) CREATE TABLE "schema_migrations" ("version" varchar(255) NOT NULL)
19
+  (25.6ms) CREATE UNIQUE INDEX "unique_schema_migrations" ON "schema_migrations" ("version")
20
+  (0.3ms) SELECT version FROM "schema_migrations"
21
+  (10.1ms) INSERT INTO "schema_migrations" (version) VALUES ('20130714091905')
@@ -0,0 +1,160 @@
1
+  (0.4ms) begin transaction
2
+ ------------------------------------------
3
+ AnisControllerTest: test_should_create_ani
4
+ ------------------------------------------
5
+  (0.1ms) rollback transaction
6
+  (0.1ms) begin transaction
7
+ -------------------------------------------
8
+ AnisControllerTest: test_should_destroy_ani
9
+ -------------------------------------------
10
+  (0.1ms) rollback transaction
11
+  (0.0ms) begin transaction
12
+ ----------------------------------------
13
+ AnisControllerTest: test_should_get_edit
14
+ ----------------------------------------
15
+  (0.1ms) rollback transaction
16
+  (0.0ms) begin transaction
17
+ -----------------------------------------
18
+ AnisControllerTest: test_should_get_index
19
+ -----------------------------------------
20
+  (0.0ms) rollback transaction
21
+  (0.0ms) begin transaction
22
+ ---------------------------------------
23
+ AnisControllerTest: test_should_get_new
24
+ ---------------------------------------
25
+  (0.0ms) rollback transaction
26
+  (0.0ms) begin transaction
27
+ ----------------------------------------
28
+ AnisControllerTest: test_should_show_ani
29
+ ----------------------------------------
30
+  (0.1ms) rollback transaction
31
+  (0.0ms) begin transaction
32
+ ------------------------------------------
33
+ AnisControllerTest: test_should_update_ani
34
+ ------------------------------------------
35
+  (0.0ms) rollback transaction
36
+  (0.0ms) begin transaction
37
+ ---------------------------
38
+ JiYingTest: test_final_page
39
+ ---------------------------
40
+  (0.3ms) rollback transaction
41
+  (0.1ms) begin transaction
42
+ --------------------------
43
+ JiYingTest: test_full_page
44
+ --------------------------
45
+  (0.1ms) rollback transaction
46
+  (0.1ms) begin transaction
47
+ --------------------------
48
+ JiYingTest: test_full_site
49
+ --------------------------
50
+  (0.1ms) rollback transaction
51
+  (0.0ms) begin transaction
52
+ --------------------
53
+ JiYingTest: test_get
54
+ --------------------
55
+  (0.1ms) rollback transaction
56
+  (0.0ms) begin transaction
57
+ ---------------------
58
+ JiYingTest: test_save
59
+ ---------------------
60
+  (0.1ms) SELECT COUNT(*) FROM "anis"
61
+  (0.1ms) SAVEPOINT active_record_1
62
+ SQL (2.3ms) INSERT INTO "anis" ("created_at", "title", "torrent", "updated_at") VALUES (?, ?, ?, ?) [["created_at", Sun, 14 Jul 2013 09:47:09 UTC +00:00], ["title", "魔法"], ["torrent", "http://baidu.com"], ["updated_at", Sun, 14 Jul 2013 09:47:09 UTC +00:00]]
63
+  (0.1ms) RELEASE SAVEPOINT active_record_1
64
+  (0.1ms) SELECT COUNT(*) FROM "anis"
65
+  (0.2ms) rollback transaction
66
+  (0.1ms) begin transaction
67
+ -----------------------
68
+ JiYingTest: test_single
69
+ -----------------------
70
+  (0.4ms) rollback transaction
71
+  (0.1ms) begin transaction
72
+ ------------------------------
73
+ JiYingTest: test_single_filter
74
+ ------------------------------
75
+  (0.4ms) rollback transaction
76
+  (0.2ms) begin transaction
77
+ ---------------------------
78
+ SpiderRailsTest: test_truth
79
+ ---------------------------
80
+  (0.2ms) rollback transaction
81
+  (0.3ms) begin transaction
82
+ ---------------------------
83
+ JiYingTest: test_final_page
84
+ ---------------------------
85
+  (0.1ms) rollback transaction
86
+  (0.1ms) begin transaction
87
+ --------------------------
88
+ JiYingTest: test_full_page
89
+ --------------------------
90
+  (0.2ms) rollback transaction
91
+  (0.1ms) begin transaction
92
+ --------------------------
93
+ JiYingTest: test_full_site
94
+ --------------------------
95
+  (0.2ms) rollback transaction
96
+  (0.1ms) begin transaction
97
+ --------------------
98
+ JiYingTest: test_get
99
+ --------------------
100
+  (0.1ms) rollback transaction
101
+  (0.1ms) begin transaction
102
+ ---------------------
103
+ JiYingTest: test_save
104
+ ---------------------
105
+  (0.1ms) SELECT COUNT(*) FROM "anis"
106
+  (0.1ms) SAVEPOINT active_record_1
107
+ SQL (2.9ms) INSERT INTO "anis" ("created_at", "title", "torrent", "updated_at") VALUES (?, ?, ?, ?) [["created_at", Sun, 14 Jul 2013 09:48:20 UTC +00:00], ["title", "魔法"], ["torrent", "http://baidu.com"], ["updated_at", Sun, 14 Jul 2013 09:48:20 UTC +00:00]]
108
+  (0.1ms) RELEASE SAVEPOINT active_record_1
109
+  (0.1ms) SELECT COUNT(*) FROM "anis"
110
+  (0.2ms) rollback transaction
111
+  (0.0ms) begin transaction
112
+ -----------------------
113
+ JiYingTest: test_single
114
+ -----------------------
115
+  (0.1ms) rollback transaction
116
+  (0.1ms) begin transaction
117
+ ------------------------------
118
+ JiYingTest: test_single_filter
119
+ ------------------------------
120
+  (0.2ms) rollback transaction
121
+  (0.1ms) begin transaction
122
+ ---------------------------
123
+ SpiderRailsTest: test_truth
124
+ ---------------------------
125
+  (0.1ms) rollback transaction
126
+  (0.4ms) begin transaction
127
+ ---------------------------
128
+ JiYingTest: test_final_page
129
+ ---------------------------
130
+  (0.2ms) rollback transaction
131
+  (0.1ms) begin transaction
132
+ --------------------------
133
+ JiYingTest: test_full_page
134
+ --------------------------
135
+  (0.2ms) rollback transaction
136
+  (0.1ms) begin transaction
137
+ --------------------------
138
+ JiYingTest: test_full_site
139
+ --------------------------
140
+  (0.3ms) rollback transaction
141
+  (0.1ms) begin transaction
142
+ --------------------
143
+ JiYingTest: test_get
144
+ --------------------
145
+  (0.2ms) rollback transaction
146
+  (0.5ms) begin transaction
147
+ ------------------------------
148
+ JiYingTest: test_single_filter
149
+ ------------------------------
150
+  (0.3ms) rollback transaction
151
+  (0.4ms) begin transaction
152
+ ---------------------
153
+ JiYingTest: test_save
154
+ ---------------------
155
+  (0.2ms) SELECT COUNT(*) FROM "anis"
156
+  (0.2ms) SAVEPOINT active_record_1
157
+ SQL (3.0ms) INSERT INTO "anis" ("created_at", "title", "torrent", "updated_at") VALUES (?, ?, ?, ?) [["created_at", Sun, 14 Jul 2013 10:22:27 UTC +00:00], ["title", "魔法"], ["torrent", "http://baidu.com"], ["updated_at", Sun, 14 Jul 2013 10:22:27 UTC +00:00]]
158
+  (0.2ms) RELEASE SAVEPOINT active_record_1
159
+  (0.2ms) SELECT COUNT(*) FROM "anis"
160
+  (0.3ms) rollback transaction
@@ -0,0 +1,58 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>The page you were looking for doesn't exist (404)</title>
5
+ <style>
6
+ body {
7
+ background-color: #EFEFEF;
8
+ color: #2E2F30;
9
+ text-align: center;
10
+ font-family: arial, sans-serif;
11
+ }
12
+
13
+ div.dialog {
14
+ width: 25em;
15
+ margin: 4em auto 0 auto;
16
+ border: 1px solid #CCC;
17
+ border-right-color: #999;
18
+ border-left-color: #999;
19
+ border-bottom-color: #BBB;
20
+ border-top: #B00100 solid 4px;
21
+ border-top-left-radius: 9px;
22
+ border-top-right-radius: 9px;
23
+ background-color: white;
24
+ padding: 7px 4em 0 4em;
25
+ }
26
+
27
+ h1 {
28
+ font-size: 100%;
29
+ color: #730E15;
30
+ line-height: 1.5em;
31
+ }
32
+
33
+ body > p {
34
+ width: 33em;
35
+ margin: 0 auto 1em;
36
+ padding: 1em 0;
37
+ background-color: #F7F7F7;
38
+ border: 1px solid #CCC;
39
+ border-right-color: #999;
40
+ border-bottom-color: #999;
41
+ border-bottom-left-radius: 4px;
42
+ border-bottom-right-radius: 4px;
43
+ border-top-color: #DADADA;
44
+ color: #666;
45
+ box-shadow:0 3px 8px rgba(50, 50, 50, 0.17);
46
+ }
47
+ </style>
48
+ </head>
49
+
50
+ <body>
51
+ <!-- This file lives in public/404.html -->
52
+ <div class="dialog">
53
+ <h1>The page you were looking for doesn't exist.</h1>
54
+ <p>You may have mistyped the address or the page may have moved.</p>
55
+ </div>
56
+ <p>If you are the application owner check the logs for more information.</p>
57
+ </body>
58
+ </html>