我想在将丹麦字符发送到数据库之前对其进行编码。
我尝试将此功能应用于他们:
private function process_array_elements(&$element){
$element = utf8_encode($element);
$element = strip_tags( $element );
$element = strtolower ( trim ( $element ) );
$element = mysql_real_escape_string($element);
return $element;
}
像这样:
$this->check_line_two = $this->process_array_elements($e);
现在,每当我尝试将字符串发送到数据库时:
mysql_query("SET NAMES 'utf8'");
$query="INSERT INTO result_scanned
SET line_one= '$this->check_line_one',
line_two='$this->check_line_two',
line_three='$this->check_line_three',
advert_id='$this->advert_id',
scanned='$this->scan_result'";
我明白了:
Incorrect string value: '\xE3\x83\xE2\xB8r ...' for column 'line_three' at row 1
表中字段的数据类型是 UTF-8 ( utf8_unicode_ci
),所以我必须使用相同的编码我的字符串
该线程与我的问题有关:Detect encoding and make everything UTF-8。
但是,在将任何字符插入数据库之前,我需要知道如何将其编码为 UTF-8,否则,我会收到上述错误。我想在将它们放入数据库之前,我需要先确定我收到的字符类型。