<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="sv">
	<id>https://wiki.linux.se/index.php?action=history&amp;feed=atom&amp;title=openssl_encrypt%28%29</id>
	<title>openssl encrypt() - Versionshistorik</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.linux.se/index.php?action=history&amp;feed=atom&amp;title=openssl_encrypt%28%29"/>
	<link rel="alternate" type="text/html" href="https://wiki.linux.se/index.php?title=openssl_encrypt()&amp;action=history"/>
	<updated>2026-04-29T00:00:04Z</updated>
	<subtitle>Versionshistorik för denna sida på wikin</subtitle>
	<generator>MediaWiki 1.38.4</generator>
	<entry>
		<id>https://wiki.linux.se/index.php?title=openssl_encrypt()&amp;diff=5692&amp;oldid=prev</id>
		<title>Admin: Skapade sidan med &#039;== openssl_encrypt == &#039;&#039;&#039;(PHP 5 &gt;= 5.3.0, PHP 7, PHP 8)&#039;&#039;&#039;  === openssl_encrypt — Krypterar data ===  ==== Beskrivning ==== &lt;pre&gt; openssl_encrypt(#[\SensitiveParameter] string $data, string $cipher_algo, #[\SensitiveParameter] string $passphrase, int $options = 0, string $iv = &quot;&quot;, string &amp;$tag = null, string $aad = &quot;&quot;, int $tag_length = 16): string|false &lt;/pre&gt;  Funktionen `openssl_encrypt()` krypterar given data med en specifik metod och lösenfras och returnerar en r...&#039;</title>
		<link rel="alternate" type="text/html" href="https://wiki.linux.se/index.php?title=openssl_encrypt()&amp;diff=5692&amp;oldid=prev"/>
		<updated>2024-10-31T16:44:30Z</updated>

		<summary type="html">&lt;p&gt;Skapade sidan med &amp;#039;== openssl_encrypt == &amp;#039;&amp;#039;&amp;#039;(PHP 5 &amp;gt;= 5.3.0, PHP 7, PHP 8)&amp;#039;&amp;#039;&amp;#039;  === openssl_encrypt — Krypterar data ===  ==== Beskrivning ==== &amp;lt;pre&amp;gt; openssl_encrypt(#[\SensitiveParameter] string $data, string $cipher_algo, #[\SensitiveParameter] string $passphrase, int $options = 0, string $iv = &amp;quot;&amp;quot;, string &amp;amp;$tag = null, string $aad = &amp;quot;&amp;quot;, int $tag_length = 16): string|false &amp;lt;/pre&amp;gt;  Funktionen `openssl_encrypt()` krypterar given data med en specifik metod och lösenfras och returnerar en r...&amp;#039;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Ny sida&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== openssl_encrypt ==&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;(PHP 5 &amp;gt;= 5.3.0, PHP 7, PHP 8)&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
=== openssl_encrypt — Krypterar data ===&lt;br /&gt;
&lt;br /&gt;
==== Beskrivning ====&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
openssl_encrypt(#[\SensitiveParameter] string $data, string $cipher_algo, #[\SensitiveParameter] string $passphrase, int $options = 0, string $iv = &amp;quot;&amp;quot;, string &amp;amp;$tag = null, string $aad = &amp;quot;&amp;quot;, int $tag_length = 16): string|false&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Funktionen `openssl_encrypt()` krypterar given data med en specifik metod och lösenfras och returnerar en rå eller base64-kodad sträng.&lt;br /&gt;
&lt;br /&gt;
==== Parametrar ====&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;data&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
Den okrypterade textmeddelandet som ska krypteras.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;cipher_algo&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
Cipher-metoden. För en lista över tillgängliga metoder, använd [[openssl_get_cipher_methods()]].&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;passphrase&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
Lösenfrasen. Om lösenfrasen är kortare än förväntat fylls den ut tyst med NUL-tecken; om lösenfrasen är längre än förväntat blir den tyst avkortad.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;options&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
Bitvis kombination av flaggorna OPENSSL_RAW_DATA och OPENSSL_ZERO_PADDING eller OPENSSL_DONT_ZERO_PAD_KEY.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;iv&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
En icke-null Initieringsvektor. Om IV:n är kortare än förväntat fylls den ut med NUL-tecken och en varning ges; om den är längre än förväntat avkortas den och en varning ges.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;tag&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
Autentiseringstaggen, skickas med referens när AEAD-cipher-läge (GCM eller CCM) används.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;aad&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
Ytterligare autentiserad data.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;tag_length&amp;#039;&amp;#039;&amp;#039;  &lt;br /&gt;
Längden på autentiseringstaggen. Värdet kan vara mellan 4 och 16 för GCM-läge.&lt;br /&gt;
&lt;br /&gt;
==== Returvärden ====&lt;br /&gt;
Returnerar den krypterade strängen vid framgång eller false vid misslyckande.&lt;br /&gt;
&lt;br /&gt;
==== Fel/Undantag ====&lt;br /&gt;
Emits ett E_WARNING-nivåfel om en okänd cipher-algoritm skickas via cipher_algo-parametern.&lt;br /&gt;
&lt;br /&gt;
Emits ett E_WARNING-nivåfel om en tom värde skickas in via iv-parametern.&lt;br /&gt;
&lt;br /&gt;
==== Ändringslogg ====&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Version !! Beskrivning&lt;br /&gt;
|-&lt;br /&gt;
| 7.1.0 || Parametrarna &amp;#039;&amp;#039;&amp;#039;tag&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;aad&amp;#039;&amp;#039;&amp;#039; och &amp;#039;&amp;#039;&amp;#039;tag_length&amp;#039;&amp;#039;&amp;#039; lades till.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Exempel ====&lt;br /&gt;
Exempel #1 AES Authenticated Encryption i GCM-läge för PHP 7.1+&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
// $key bör ha genererats på ett kryptografiskt säkert sätt, t.ex. med openssl_random_pseudo_bytes&lt;br /&gt;
$plaintext = &amp;quot;message to be encrypted&amp;quot;;&lt;br /&gt;
$cipher = &amp;quot;aes-128-gcm&amp;quot;;&lt;br /&gt;
if (in_array($cipher, openssl_get_cipher_methods())) {&lt;br /&gt;
    $ivlen = openssl_cipher_iv_length($cipher);&lt;br /&gt;
    $iv = openssl_random_pseudo_bytes($ivlen);&lt;br /&gt;
    $ciphertext = openssl_encrypt($plaintext, $cipher, $key, $options=0, $iv, $tag);&lt;br /&gt;
    // Spara $cipher, $iv och $tag för dekryptering senare&lt;br /&gt;
    $original_plaintext = openssl_decrypt($ciphertext, $cipher, $key, $options=0, $iv, $tag);&lt;br /&gt;
    echo $original_plaintext.&amp;quot;\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Exempel #2 AES Authenticated Encryption före PHP 7.1&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
// $key tidigare genererat på ett säkert sätt, t.ex. med openssl_random_pseudo_bytes&lt;br /&gt;
$plaintext = &amp;quot;message to be encrypted&amp;quot;;&lt;br /&gt;
$ivlen = openssl_cipher_iv_length($cipher=&amp;quot;AES-128-CBC&amp;quot;);&lt;br /&gt;
$iv = openssl_random_pseudo_bytes($ivlen);&lt;br /&gt;
$ciphertext_raw = openssl_encrypt($plaintext, $cipher, $key, $options=OPENSSL_RAW_DATA, $iv);&lt;br /&gt;
$hmac = hash_hmac(&amp;#039;sha256&amp;#039;, $ciphertext_raw, $key, $as_binary=true);&lt;br /&gt;
$ciphertext = base64_encode($iv.$hmac.$ciphertext_raw);&lt;br /&gt;
&lt;br /&gt;
// Dekryptera senare...&lt;br /&gt;
$c = base64_decode($ciphertext);&lt;br /&gt;
$ivlen = openssl_cipher_iv_length($cipher=&amp;quot;AES-128-CBC&amp;quot;);&lt;br /&gt;
$iv = substr($c, 0, $ivlen);&lt;br /&gt;
$hmac = substr($c, $ivlen, $sha2len=32);&lt;br /&gt;
$ciphertext_raw = substr($c, $ivlen+$sha2len);&lt;br /&gt;
$original_plaintext = openssl_decrypt($ciphertext_raw, $cipher, $key, $options=OPENSSL_RAW_DATA, $iv);&lt;br /&gt;
$calcmac = hash_hmac(&amp;#039;sha256&amp;#039;, $ciphertext_raw, $key, $as_binary=true);&lt;br /&gt;
if (hash_equals($hmac, $calcmac)) { // säker jämförelse för timing-attacker&lt;br /&gt;
    echo $original_plaintext.&amp;quot;\n&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Se även ====&lt;br /&gt;
* [[openssl_decrypt()]] - Dekrypterar data&lt;br /&gt;
&lt;br /&gt;
= Sidslut =&lt;br /&gt;
&lt;br /&gt;
Orginalhemsidan på Engelska :https://www.php.net/manual/en/function.openssl-encrypt.php&lt;br /&gt;
[[PHP]]&lt;br /&gt;
[[Funktioner]]&lt;br /&gt;
[[Funktionsreferens]]&lt;br /&gt;
[[OpenSSL-funktioner]]&lt;br /&gt;
&amp;lt;HR&amp;gt;&lt;br /&gt;
Det här är en maskinöversättning av PHP-manualen till svenska. Om du hittar fel är vi tacksamma om du rapporterar dem via formuläret som finns på &lt;br /&gt;
https://www.linux.se/kontaka-linux-se/&lt;br /&gt;
&amp;lt;BR&amp;gt;&amp;lt;BR&amp;gt;Tack till [https://datorhjalp.se Datorhjälp] som har  sponsrat [https://www.linux.se Linux.se] med webserver.&lt;br /&gt;
&lt;br /&gt;
[[Kategori:Php]]&lt;br /&gt;
[[Kategori:Kryptografi-extensioner]]&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
</feed>