�uGoogle���Ǝ㐫����u�v�ƁA�Z�L�����e�B��Ƃ��ᔻ

���Ђɑ����Ή���v�����Ȃ��玩�Ђ̑Ή��ɊÂ��ƁASecurity Explorations���w�E����B

» 2015�N05��18�� 07��30�� ���J
[��ؐ��q�CITmedia]

�@��Google�́uGoogle App Engine�iGAE�jfor Java�v�Ɍ��‚����������̐Ǝ㐫���������̂܂܂ɂȂ��Ă���Ƃ��āA�|�[�����h�̃Z�L�����e�B���Security Explorations��5��15���A�ڂ������ƃR���Z�v�g���؃R�[�h�����J�����BGoogle�͑��Ђɑ΂��Ă͑����ɑΉ���v�����Ă����Ȃ���A���������̐��i�ɕ񍐂��ꂽ�Ǝ㐫�͕��u������ق��ďC�������肵�Ă���Ɣᔻ���Ă���B

�@Security Explorations�ɂ��ƁA���Ђ�2014�N12���ȗ��AGAE�ɑ����̐Ǝ㐫�𔭌�����Google�ɕ񍐂��AGoogle���C���Ȃǂ̑Ή����u���Ă����B�������܂��������̐Ǝ㐫�������c���Ă��āA���p���ꂽ�ꍇ�A�U���҂��T���h�{�b�N�X�𔲂��o���ĔC�ӂ̃R�[�h�����s�ł��Ă��܂����ꂪ����Ƃ����B

�@����疢�����̐Ǝ㐫�ɂ‚��Ă͕񍐂���3�T�Ԃ����Ă�Google�͊m�F���ے�����Ă��Ȃ���Security Explorations�͓`���A�u���E���ɉ��S�l���̃Z�L�����e�B�Z�p�҂�����Ǝ咣���Ă��āA���Ђɑ΂��Ă͑����ɑΉ����邱�Ƃ����҂��Ă���x���_�[�����ɁA���ɗJ�������v�Ǝw�E����B

�@�܂��A�ꕔ�̐Ǝ㐫��Google��Security Explorations�ɘA�����Ȃ��܂܏C�����Ă������Ƃ����������Ƃ��āA�u���Ђ́w�ق��ďC���x�̃A�v���[�`������ꂪ�o�������̂͂����3�x�ځv���Ƃ��ᔻ�����B

�@����܂ł�Google�ɕ񍐂����Ǝ㐫�́A�S��GAE��Java�̐Ǝ㐫������ړI��JRE�̏�Ɏ������ꂽ�u�lj��I�Z�L�����e�B�v�̑w�ɑ��݂��Ă����A��Security Explorations�͓`���Ă���B

�֘A�L�[���[�h

Google | �Ǝ㐫 | �ᔻ | Google App Engine


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);

�l�C�L�������L���O

���Ȃ��ɂ������߂̋L��PR