Übergeben Sie eine Variable verzögert an ein HTML-Element in einer PHP-Seite oder ersetzen Sie sie durch einen aktualisierten Wert
P粉253800312
P粉253800312 2023-08-17 22:55:08
0
1
545
<p><br /></p> <pre class="brush:bash;toolbar:false;">/public/register.php ## [1] „öffentliches“ Registrierungsformular /public/js/checkout.js ## [2] „öffentliche“ Zahlungsabwicklung /src/register.php ## [3] „private“ zusätzliche Verarbeitung </pre> <ul> <li>[1] Laden über <code><script src="js/checkout.js"></script></code> <li>[1] via <code>require __DIR__ '/../src/register.php';</code> enthält [3]</li> </ul> <p>[1] enthält ein HTML-Element (als HTML-Code in der PHP-Datei enthalten, d. h. außerhalb des <code><php ... ?></code>-Tags): </p> ; <pre class="brush:html;toolbar:false;"><div id="secret" style="display: none;"> <?php echo htmlspecialchars($secret_var); ?> </div> </pre> <p><code>$secret_var</code> wird in [3] deklariert/instanziiert. </p> <p>[2] Diese JS-Datei enthält </p> <pre class="brush:js;toolbar:false;">var div = document.getElementById("secret"); var Secret_var = div.textContent; console.log(secret_var) </pre> <p>[3] enthält</p> <pre class="brush:php;toolbar:false;">session_start(); // Verarbeitungscode des Zahlungspartners, Antwort $secret_var = json_encode(array(secret_var); $_SESSION['secret_var'] = $secret_var; </pre> <p><code>$secret_var</code> wird als <code>$_SESSION</code>-Variable von [3] an [1] übergeben, wo [2] sie abruft. </p> <p>Beim Echo von <code>$secret_var</code> im Browser der <code>console.log</code>-Anweisung wird <code>null</code> zurückgegeben. </p> <p>Beim Echo von <code>$secret_var</code> von <code>src/register.php</code> (angezeigt auf der gerenderten <code>registration.php</code>-Seite). hat den richtigen (String-)Wert. </p> <p>Wie kann ich die Übergabe von <code>$secret_var</code> an das HTML-Element <code>#secret</code> verzögern oder es durch einen aktualisierten Wert (nicht Null) ersetzen? </p>
P粉253800312
P粉253800312

Antworte allen(1)
P粉895187266

猜测您在执行顺序方面遇到了问题,比如在DOM中甚至还不存在<div id="secret">时,[2]脚本就已经执行了。您可以在输出<script src="js/checkout.js"></script>之前,简单地在[1]处添加类似于<script>var secret_var = <?= json_encode($secret_var); ?>;</script>的内容,这样它就在checkout.js执行之前就是公开的并且已知的,而且已经作为变量存在,无需读取元素内容。或者只需使用事件,如window.onload来执行[2]对元素的读取。

如果该秘密值发生变化并且您需要进行更新,您可以定期检查变化,或者更好地在使用之前请求最新的值。

请注意,您输出到客户端的任何内容都不再是秘密,如果您真的想保护某个值,您必须将其仅保留在服务器端,这在像支付网关的API密钥等情况下非常重要。服务器端意味着将秘密存储在数据库或会话中。然后,每当您需要与远程服务交互时,只需调用PHP脚本(例如ajax)在服务器端执行该任务,这样您就将秘密的使用分离到仅限服务器端,然后您无需将其传递给客户端或请求更新。

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage