일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- C# IO
- chart.js
- 우분투
- 폼메일
- 자바스크립트
- soundpool
- C#
- Android
- php 취약점
- dovecot
- android 효과음
- curl
- 안드로이드 푸쉬
- 안드로이드
- UML
- PHP
- html5
- 안드로이드 푸시
- 안드로이드 gcm
- php 시큐어코딩
- 설치
- mysql
- javascript
- xe
- 자동 생성
- roundcube
- Mail Server
- FCM
- WebView
- not working
- Today
- Total
그러냐
허프만 php 문자 압축 소스 HUFFMAN CODING WITH PHP AND JAVASCRIPT 본문
HUFFMAN CODING WITH PHP AND JAVASCRIPT
There may be times when you want to compress data on the server or in the browser. I’m providing an implementation of the Huffman Coding algorithm in PHP and in JavaScript.
Download Source Code
Simple String Compression
PHP Example (in JavaScript, it’s almost the same):
<?php
$original = "This is the text that you want to compress.";
$huffman = new Huffman();
$compressed = $huffman->compress($original);
/* ... */
$huffman2 = new Huffman();
$decompressed = $huffman2->decompress($compressed);
echo $decompressed; // Should output "This is a text..."
?>
Simple Array Compression
You can also compress arrays which may contain any kind of data (numbers, objects, strings, etc.). What you get after compression, however, is also an array which contains these objects. This is needed to properly restore the original data during decompression.
JavaScript example (it’s the same in PHP):
var original = new Array(1000,1000,"text",1000,1000,"text",new Array());
var huffman = new Huffman();
var compressed = huffman.compress(original);
/* ... */
var huffman2 = new Huffman();
alert(huffman2.decompress(compressed)); // Should display the original array items.
Re-using Huffman Trees
In the above examples, the Huffman tree (also called the “dictionary”) which maps values (or characters) to bits is embedded in the compressed data. Sometimes, however, you may want to re-use the dictionary for more than one item to compress. This is how it works:
<?php
$original1 = "This is the first text we want to compress.";
$original2 = "This is the second text we want to compress.";
$huffman = new Huffman();
$huffman->buildTree($original1.$original2);
$dictionary = $huffman->getDictionary();
$compressed1 = $huffman->compressData($original1,false);
$compressed2 = $huffman->compressData($original2,false);
/* ... */
$huffman2 = new Huffman($dictionary);
echo $huffman->decompressData($compressed1,false)."\n";
echo $huffman->decompressData($compressed2,false);
// Should output both original strings.
?>
This works exactly the same with arrays but you’ll have to let the functions know that you want arrays with “true” instead of “false” in the functions above. See also documentation in source code.
And of course, this also works in JavaScript.
Javascript Tip
If you load a binary file from the server using AJAX, you should make sure you override the MIME type as follows:
// xmlhr is an XMLHttpRequest object.
xmlhr.overrideMimeType('text/plain; charset=x-user-defined');
출처 : https://code.kuederle.com/huffman/
'php' 카테고리의 다른 글
웹 보안 (0) | 2017.02.27 |
---|---|
국내 해외 IP 구분 JSON 으로 받기 (0) | 2017.02.06 |
PHP 세션 유지 ( session timeout ) 설정 (0) | 2017.01.26 |
php 폼메일 소스 mail() (0) | 2017.01.09 |
strlen, strpos, strimwidth, substr, mb_strimwidth 길이 문제 (0) | 2016.11.16 |