�uUPnP�v�ɐƎ㐫������A���[�^�Ȃǐ��疜��ɉe��
» 2013�N01��30�� 07��34�� ���J
�@���[�^�Ȃǂ̃l�b�g���[�N�@��ɍL���g���Ă���uUniversal Plug and Play�v�iUPnP�j�ɕ����̐Ǝ㐫���m�F���ꂽ�B��胁�[�J�[�e�Ђ̐��i���܂ސ��疜�䂪�e������Ƃ���A�ăZ�L�����e�B�@�ւ�US-CERT�̓��[�J�[��f�x���b�p�[�ɑ��A�A�b�v�f�[�g��K�p���ĐƎ㐫���C������悤�Ăъ|���Ă���B
�@US-CERT��1��29���Ɍ��J�����Z�L�����e�B���ɂ��AUPnP�f�o�C�X�p�̃I�[�v���\�[�X�|�[�^�u��SDK�ł���ulibupnp�v�Ƀo�b�t�@�I�[�o�[�t���[�̐Ǝ㐫���������݂���B����ɁAlibupnp���g���Ă���f�o�C�X��WAN�C���^�t�F�[�X�o�R��UPnP�N�G���[������Ă��܂��\��������A�Ǝ㐫���C���^�[�l�b�g�ɘI�o����鋰�ꂪ����B
�@�Ǝ㐫�́A�Z�L�����e�B��Ƃ�Rapid7���C���^�[�l�b�g�ڑ����ꂽUPnP�f�o�C�X��Ώۂɍs������K�͒����v���W�F�N�g�Ŕ����Blibupnp��Simple Service Discovery Protocol�iSSDP�j�����ɐƎ㐫������A�����[�g�̔F���Ȃ��U���҂��A�f�o�C�X��ŔC�ӂ̃R�[�h�����s�ł��Ă��܂����ꂪ����B
�@Rapid7�ɂ��Alibupnp��Cisco Systems�A�x�m�ʁANEC�A�\�j�[�Ȃǂ̑����܂�200�Јȏ�̐��i�ɍ̗p����A���疜����̃l�b�g���[�N�@��Ɏg���Ă���B���̂�����2000���䂪�C���^�[�l�b�g�ɘI�o���Ă���Ƃ����B�l�b�g���[�N�@��̂ق��ɂ��X�g���[�~���O���f�B�A��t�@�C�����L�A�v���P�[�V�����̑������Alibrary�o�R�ōU���ɂ��炳��鋰�ꂪ����Ƃ����B
1��29�����݂ł̎�v�x���_�[�̉e���iUS-CERT���j
�@29���ɂ͂����Ǝ㐫�ɑΏ������X�V�ł́ulibupnp 1.6.18�v�����J���ꂽ�B�������A�e���[�J�[�����̃p�b�`�����А��i�Ɏ������ɂ͎��Ԃ�������A�o�ׂ��ł���ꂽ���i�ɂ̓A�b�v�f�[�g���z�z����Ȃ���������Ȃ���Rapid7�͗\�z����B
�@���̂���US-CERT�ł́A�\�ł����UPnP���ɂ��A�C���^�[�l�b�g�ȂǐM���ł��Ȃ��l�b�g���[�N�����SSDP�i1900/upd�j�����Simple Object Access Protocol�iSOAP�j�T�[�r�X�ɐ�����������Ȃǂ̑�����サ�Ă���B
Copyright © ITmedia, Inc. All Rights Reserved.
';
e_dlv.innerHTML = html;
adRequest({position:dlv_pos,dom:true});
}else if(ad_type === 'gam'){
var html = '
';
e_dlv.innerHTML = html;
refreshGam('InArtSpecialLink');
}else if(ad_type === 'logly'){
var html = '
';
e_dlv.innerHTML = html;
loglySet(g_id);
}else if(ad_type === 'google'){
var html = '
';
e_dlv.innerHTML = html;
googletag.cmd.push(function(){
var slot8 = googletag.defineSlot('/43042345/nlab_artinsert_RT',[[336,280],[300,250],'fluid'],'div-gpt-ad-1551176482959-0').addService(googletag.pubads());
googletag.pubads().enableSingleRequest();
googletag.enableServices();
googletag.display('div-gpt-ad-1551176482959-0');
googletag.pubads().refresh([slot8]);
});
}
};
var insert_ok = function(_target,_str){
var clearfix = d.createElement('div');
clearfix.className = 'colBoxClear';
if(ad_float_fix){
e_body.insertBefore(e_dlv,_target);
e_body.insertBefore(clearfix,_target.nextElementSibling);
}else{
e_body.insertBefore(e_dlv,_target);
}
set_dlv();
};
var insert_ng = function(_str){
e_dlv.style.display = 'none';
};
var main = function(){
var e_nodes = e_body.childNodes; // BODY �����q�v�f
var e_tags = []; // BODY �����^�O
var p_num = []; // BODY ���� P �^�O�ʒu
var p_target_num; // �g�}����ʒu
var o_float = {}; // ��荞�ݗv�f
var o_this = {}; // �A�N�e�B�u�^�O
var o_next = {}; // �A�N�e�B�u�^�O�̎��̃^�O
var flag_insert = 0; // �}���t���O
// ��荞�ݗv�f�`�F�b�N
var check_float = function(_e){
var e = 0;
if(_e.id.match(/^col\d{3}(l|r)$/)){
e = _e;
}
return e;
};
// �v�f�� Y ���W�ƍ����̍��v�l
var get_element_y = function(_e){
var ey = 0;
var eh = _e.offsetHeight;
while(_e){
ey += _e.offsetTop;
_e = _e.offsetParent;
}
return ey + eh;
};
var check_ptag = function(_e){
var e = 0;
if(_e.tagName && _e.tagName === 'P'){
e = _e;
}
return e;
};
var try_insert = function(){
p_target_num = Math.floor(p_num.length / 2) - 1;
if(p_target_num >= _maxrange) p_target_num = _maxrange;
if(dis_con) p_target_num = 0;
for(var i = p_num[p_target_num]; i < e_tags.length; i++){
o_this.e = check_ptag(e_tags[i]);
if(o_this.e){
o_next.e = check_ptag(e_tags[i + 1]);
if(o_next.e){
if(!o_float.e || check_float(e_tags[i - 1])){
o_float.e = check_float(e_tags[i - 1]);
o_float.n = i - 1;
}
if(o_float.e && o_float.n < i + 1){
o_float.y = get_element_y(o_float.e);
o_this.y = get_element_y(o_this.e);
set_line(o_float.y,'red');
set_line(o_this.y,'blue');
if(o_float.y < o_this.y){
flag_insert = 1;
insert_ok(o_next.e,_threshold + ' �p���ȏ��荞�݂���');
break;
}
}else{
flag_insert = 1;
insert_ok(o_next.e,_threshold + ' �p���ȏ��荞�݂Ȃ�');
break;
}
}
}else{
o_float = {};
}
}
if(!flag_insert){
insert_ng('�}���ʒu�Ȃ�');
}
};
// �S�q�v�f����^�O�̂ݔz��ɓ����
for(var i = 0; i < e_nodes.length; i++){
if(e_nodes[i].tagName){
e_tags.push(e_nodes[i]);
}
}
// �S�^�O���� P �^�O�ʒu��z��ɓ����
for(var i = 0; i < e_tags.length; i++){
if(e_tags[i].tagName === 'P') p_num.push(i);
// �ŏ��̉�荞�ݗv�f���i�[
if(!o_float.e){
o_float.e = check_float(e_tags[i]);
o_float.y = get_element_y(o_float.e);
o_float.n = i;
}
}
if(p_num.length >= _threshold){
try_insert();
}else{
insert_ng('P �^�O ' + _threshold + ' �ȉ�');
}
};
if(e_body){
main();
}else{
insert_ng('�L���{���Ȃ�');
}
})(document,4,5);