2016-03-24 18 views
-2

に投稿された私は、レールのプロジェクトにクロスサイトスクリプティングを使用してJavaScriptのハックを見てWebセキュリティのチュートリアルをやって新しいコーダです。javascriptのハック - コードの注入が

私のプロジェクトでは、account_settings.html.erbのuser_first_name入力フィールドに悪意のあるjavascriptを挿入しています。このフィールドには、更新するたびに新しいデータを訪問するたびにハッキングされたというダイアログボックスが生成されますページ。

問題:私たちのプロジェクトからこの不正なコードを取り除く方法を教えずに講師が終了し、迷惑なダイアログボックスのショットを取得できません。

私は、ビューページのソースにXSSコードを見ることができますが、私は、ビューに私のプロジェクトでそれを見つけるのは難しいが午前も私は崇高で、コマンドT機能を使用して、それを調達することができます。

私は単にXSSコードのこの注入は私のプロジェクトの中に見つけることができるか、私はそれをクリアすることができるように掲載されている場所へとステアリング、セキュリティのアドバイスを求めていません。

enter image description hereenter image description here

new.html.erb

<div class="row-fluid"> 
    <div class="span12"> 

     <div class="row-fluid"> 
      <div class="span4 offset4"> 
      <div class="signup"> 
     <%= form_for @user, :html => {:id => "account_edit", :class=> "signup-wrapper"} do |f| %> 

      <div class="header"> 
        <h2>Sign Up</h2> 
        <p>Fill out the form below to login</p> 
        </div> 

      <div class="content"> 
       <%= f.text_field :email, {:class => "input input-block-level", :placeholder => "Email"} %> 

       <%= f.text_field :first_name, {:class => "input input-block-level", :placeholder => "First Name"} %> 

       <%= f.text_field :last_name, {:class => "input input-block-level", :placeholder => "Last Name"} %> 

        <div class="control-group"> 
        <%= f.password_field :password, {:class => "input input-block-level", :placeholder => "Password"}%> 
       </div> 
       <div class="control-group"> 
        <%= f.password_field :password_confirmation, {:class => "input input-block-level", :placeholder => "Confirm Password"}%> 
       </div> 
      </div> 

      <div class="actions"> 
      <%= f.submit "Submit", {:id => 'submit_button', :class => "btn btn-info btn-large pull-right"} %> 
      </div> 
      <div class="clearfix"></div> 
     <% end %> 

      </div> 
      </div> 
     </div> 

    </div> 
</div> 

account_settings.html.erb

<div class="dashboard-wrapper"> 
    <div class="main-container"> 
    <div class="row-fluid"> 
     <div class="span12"> 
     <div id="success" style="display: none;" class="alert alert-block alert-success fade in"> 
       <h4 class="alert-heading"> 
        Success! 
       </h4> 
       <p> 
        Information successfully updated. 
       </p> 
       </div> 
     </div> 
    </div> 
    <div class="row-fluid"> 
     <div class="span12"> 
     <div id="failure" style="display: none;" class="alert alert-block alert-error fade in"> 
        <h4 class="alert-heading"> 
         Error! 
        </h4> 
        <p> 
         Failed to update. 
        </p> 
        </div> 
     </div> 
    </div> 
    <div class="row-fluid"> 
     <div class="span6"> 
      <div class="widget"> 
      <div class="widget-header"> 
       <div class="title"> 
       <span class="fs1" aria-hidden="true" data-icon="&#xe090;"></span> Profile Settings 
       <span class="mini-title"> 
        Edit your account details 
       </span> 
       </div> 
      </div> 
      <div class="widget-body"> 
      <%= form_for @user, :html => {:id => "account_edit"} do |f|%> 
       <%= f.hidden_field :user_id%> 
      <div class="control-group"> 
        <%= f.label :email, nil, {:class => "control-label"}%> 
      <%= f.text_field :email, {:class => "span12"}%> 
      </div> 

      <div class="control-group"> 
      <%= f.label :first_name, nil, {:class => "control-label"}%> 
      <%= f.text_field :first_name, {:class => "span12"} %> 
      </div> 

      <div> 
      <%= f.label :last_name, nil, {:class => "control-label"}%> 
      <%= f.text_field :last_name, {:class => "span12"} %> 
      </div> 

      <div class="control-group"> 
      <%= f.label :password, nil, {:class => "control-label"}%> 
      <%= f.password_field :password, {:class => "span12", :placeholder => "Enter Password"}%> 
      </div> 

      <div class="control-group"> 
       <%= f.label :password_confirmation, nil, {:class => "control-label"}%> 
       <%= f.password_field :password_confirmation, {:class => "span12", :placeholder => "Enter Password"} %> 
      </div> 

      <div class="form-actions no-margin"> 
      <%= f.submit "Submit", {:id => 'submit_button', :class => "btn btn-info pull-right"} %> 
      </div> 

      <div class="clearfix"> 
       </div> 
      <% end %> 

     </div> 
    </div> 
    </div> 
</div> 

<%= javascript_include_tag ('validation.js')%> 

<script type="text/javascript"> 

$("#submit_button").click(function(event) { 
    var valuesToSubmit = $("#account_edit").serialize(); 
    event.preventDefault(); 
    $.ajax({ 
     url: <%= "https://stackoverflow.com/users/#{current_user.user_id}.json".inspect.html_safe %>, 
    data: valuesToSubmit, 
    type: "POST", 
    success: function(response) { 
    if (response.msg == "failure") { 
     $('#failure').show(500).delay(1500).fadeOut(); 
    } else { 
     $('#success').show(500).delay(1500).fadeOut(); 
    } 
    }, 
    error: function(event) { 
    $('#failure').show(500).delay(1500).fadeOut(); 
    } 
    }); 
}); 

</script> 

_header.html.erb

<header> 
    <span style="color:#eee;margin-left:10px;"> 
    Font Size: 
    <a href="<%= home_dashboard_index_path %>?font=8pt" style="font-size:10pt;color:#eee;">A</a> 
    <a href="<%= home_dashboard_index_path %>?font=200%25" style="font-size:18pt;color:#eee;">A</a> 
    </span> 
    <div class="user-profile"> 
     <a data-toggle="dropdown" class="dropdown-toggle"> 
     <img src=" <%= image_path('profile_color.jpg')%>" alt="profile"> 

     </a> 
     <span class="caret"></span> 
     <ul class="dropdown-menu pull-right"> 
     <li> 
     <%= link_to "account settings", user_account_settings_path(:user_id => current_user.user_id) %> 
     </li> 
     <li> 
      <%= link_to "logout", logout_path %> 
     </li> 
     </ul> 
    </div> 
    <ul class="mini-nav"> 
    <li style="color: #FFFFFF"> 
    <!-- 
    I'm going to use HTML safe because we had some weird stuff 
    going on with funny chars and jquery, plus it says safe so I'm guessing 
    nothing bad will happen 
    --> 
    Welcome, <%= current_user.first_name.html_safe %> 

    </li> 
    </ul> 
</header> 
+0

は 'cはRailsの'<%= current_user.first_name.html_safe%>'なぜ 'html_safe'メソッドが必要ですか?このメソッドを削除すると、xssは実行できません。 –

+0

私は彼らの中で、それは逆効果であることを理解している必要はありません、講師は開始時に、私は注射は今、今、私のproject_に常駐し、注射を_where –

+0

私のプロジェクトに存在する場所を見つけるために探していることを私たちに語りました - ここで、 '<%= current_user.first_name.html_safe%>' –

答えて

1

あなたはそれを保存した場合、実行すくいデシベル:リセット(これはDB AND CLEAR ALLが入るリセットされます) または あなたはエントリを保存したい場合は、コマンドにアクセスしてくださいあなたのレールのプロジェクトとタイプのラインは 'X = database_name.find_by(id_of_entery') 'x.destroy'

ここでクールなレールコンソールガイドhttps://pragmaticstudio.com/blog/2014/3/11/console-shortcuts-tips-tricks

+0

ご理解いただきありがとうございます私は何を求めていたのか、一貫した答えを提供していました。 –

関連する問題