如何以及在何处记录 octobercms 会话中的数据

how and where to record data in a session on octobercms

我想在session中记录一个表单的数据

我在文档中发现我必须使用:Session::put('key', 'value'); 但我不知道在哪里放置这段代码。

知道我的表格位于 form_commun_1.htm 页面。

这是全部页面:

title = "formulaire_commun_1"
url = "/formulaire_commun_1"
layout = "sidebar_layout"
is_hidden = 0
==





 <ul class="progressbar">
 <li class="active">transaction</li>
 <li>details</li>
 <li>confirmation</li>
 </ul>

 <br><br><br><br>




 <form method="POST" action=""  name="formu" accept-charset="UTF8"  enctype="multipart/form-data">
        <input type="hidden" name="_handler" value="onUpdate">
                {{form_token()}}
                {{form_sessionkey()}}
<div class="form-group">
  <label for="TYPE_transaction" class="col-sm-3">type de transaction:</label>
   <div class="col-sm-9">
     <select class="form-control" id="TYPE_transaction">
    <option>vendre</option>
    <option>louer</option>

  </select>
    </div>
    <br><br><br>


 <p>choisissez un type de bien:</p>
 <br><br>

<div class="col-sm-offset-2 col-sm-2">
 <button class="btn btn-default"   onclick="type_bien(0)"><img src="{{ 'assets/img/icones/icone_maison.png'|theme }}"></button>
  </div>
 <div class="col-sm-offset-2 col-sm-2">

 <button class="btn btn-default"   onclick="type_bien(1)"><img src="{{ 'assets/img/icones/icone_villa.jpg'|theme }}"></button>

 </div>
 <div class="col-sm-offset-2 col-sm-2">
 <button class="btn btn-default"   onclick="type_bien(2)"><img src="{{ 'assets/img/icones/icone_riad.jpg'|theme }}"></button>

 </div>


<br><br><br><br><br>

<div class="col-sm-offset-2 col-sm-2">
 <button class="btn btn-default"   onclick="type_bien(3)"><img src="{{ 'assets/img/icones/icone_appartement.png'|theme }}"></button>

  </div>
 <div class="col-sm-offset-2 col-sm-2">

 <button class="btn btn-default"   onclick="type_bien(4)"><img src="{{ 'assets/img/icones/icone_ferme.png'|theme }}"></button>

 </div>
 <div class="col-sm-offset-2 col-sm-2">
 <button class="btn btn-default"   onclick="type_bien(5)"><img src="{{ 'assets/img/icones/icone_magasin.jpg'|theme }}"></button>


 </div>

 <br><br><br><br>



 <div class="radio"   style="display: none;" >
<label><input type="radio" name="radio_type_bien" id=0  value="maison" ></label>

 </div>
  <div class="radio" >
 <label><input type="radio" name="radio_type_bien" id=1  value="villa"></label>

 </div>
  <div class="radio" >
<label><input type="radio" name="radio_type_bien" id=2 value="riad" ></label>

 </div>
  <div class="radio" >
<label><input type="radio" name="radio_type_bien" id=3  value="appartement" ></label>

 </div>
  <div class="radio" >
<label><input type="radio" name="radio_type_bien" id=4  value="formulaire_appartement" ></label>

 </div>
  <div class="radio" >
<label><input type="radio" name="radio_type_bien" id=5 value="magasin" ></label>

 </div>


<br><br><br><br><br><br



<div class=" col-sm-offset-3 col-sm-9">

 <button type="submit" class="btn btn-default">Register</button>


</div></div>


</form> 


      <script type = "text/javascript">


function type_bien(x){

    switch( x) {
    case 0:


        document.getElementById(0).checked="true";
        document.forms["formu"].action="formulaire_villa";


        break;
    case 1:

        document.getElementById(1).checked="true";
        document.forms["formu"].action="formulaire_villa";


        break;
    case 2:

        document.getElementById(2).checked="true";
        document.forms["formu"].action="formulaie_riad";

        break;

    case 3:


        document.getElementById(3).checked="true";
        document.forms["formu"].action="formulaire_appartement";


        break;
    case 4:

        document.getElementById(4).checked="true";

        break;
    case 5:

        document.getElementById(5).checked="true";

        break;
    default:
         alert('local_commerce est selected');
}

}
      </script>

我必须完成创建插件或组件的过程吗? 在哪里放置会话以及如何使用它?

请帮忙?谢谢

我建议创建一个插件和组件,但在您的情况下这不是 100% 必要的。

这是一个基本的独立页面,可以满足您的要求:

title = "test"
url = "/test"
layout = "default"
is_hidden = 0
==
<?php
function onStart()
{
    $this['example'] = Session::get('example-key');
}

function onTest()
{
    Session::put('example-key', input('my-input'));
}

?>
==

<form data-request="onTest" data-request-success="location.reload();">
    <input type="text" name="my-input">
    <button type="submit">Submit</button>
</form>

{% if example %}
    <strong>Example: {{ example }}</strong>
{% endif %}

我建议通读 OctoberCMS documentation,非常棒。