随着移动智能终端的普及,未成年人首次触网的年龄不断降低。根据中国互联网络信息中心第48次《中国互联网络发展状况统计报告》显示,截至2021年6月,中国网民规模为10.11亿人,6—19岁网民占15.7%,共1.58亿人。同时根据第十次中国未成年人互联网运用调查显示,中国未成年人互联网普及率为99.2%,显著高于71.6%的全国平均普及率。10岁前接触互联网的比例达到78%,首次触网年龄集中在6~10岁。这些数据表明,未成年人上网低龄化趋势明显,面对互联网的“诱惑”,未成年人还未树立正确的价值观,没有很好的自控力,所以加强面向未成年人的产品、服务、广告等管控刻不容缓。
对于手机App里的商业广告,很多家长希望广告可以进行分级,比如18岁以下的人群,不再收到酒水、整形、化妆品类广告;还有,按照广告法规定,针对不满14周岁的未成年人的商品或者服务的广告,不要含有诱导家长购买或可能引发孩子模仿的不安全行为等;在儿童占比较多的童话故事、动画App里尽量不出现广告。
那么针对未成年保护的需求,如何为未成年人投放适合他们观看的内容和广告,实现内容分级的同时还能根据不同受众人群精准投放广告呢?HMS Core广告服务基于受众人群请求广告能力助力App筛选人群设置广告投放。
HMS Core广告服务SDK可通过设置RequestOptions对象,来满足针对不同受众人群请求对应广告内容的能力。该对象通过HwAds静态方法获取应用的全局受众人群信息。
在开发前需要集成HMS Core SDK和HUAWEI Ads SDK,具体步骤可参考文档。
RequestOptions提供了7种方法设置受众人群:
// 面向儿童的设置,表明广告内容需要符合COPPA的规定
RequestOptions requestOptions = HwAds.getRequestOptions().toBuilder().setTagForChildProtection(TAG_FOR_CHILD_PROTECTION_TRUE).build();
TAG_FOR_CHILD_PROTECTION_TRUE:表明广告内容需要符合COPPA的规定。TAG_FOR_CHILD_PROTECTION_FALSE:表明广告内容不需要符合COPPA的规定。
TAG_FOR_CHILD_PROTECTION_UNSPECIFIED:表明不希望明确广告内容是否需要符合COPPA的规定。
// 未达到法定承诺年龄的用户的设置,表明希望广告请求符合未达到法定承诺年龄用户的广告标准
RequestOptions requestOptions = HwAds.getRequestOptions().toBuilder().setTagForUnderAgeOfPromise(PROMISE_TRUE).build();
PROMISE_TRUE:表明希望按适合未达到法定承诺年龄的用户的方式来处理广告请求。
PROMISE_FALSE:表明不希望按适合未达到法定承诺年龄的用户的方式来处理广告请求。
PROMISE_UNSPECIFIED:表明未明确是否按适合未达到法定承诺年龄的用户的方式来处理广告请求。
提示:设置了PROMISE_TRUE后广告平台的返回的广告数量可能会少一些。
// 广告内容过滤,指定返回的广告内容应与分级标签名称对应,但不得高于W
RequestOptions requestOptions = HwAds.getRequestOptions().toBuilder().setAdContentClassification(AD_CONTENT_CLASSIFICATION_W).build();
AD_CONTENT_CLASSIFICATION_W:适合幼儿及以上年龄段的受众,仅展示内容分级为W的内容。
AD_CONTENT_CLASSIFICATION_PI:适合少儿及以上年龄段的受众,展示内容分级为PI、W的内容。
AD_CONTENT_CLASSIFICATION_J:适合青少年及以上年龄段的受众,展示内容分级为J、PI、W的内容。
AD_CONTENT_CLASSIFICATION_A:仅适合成人受众,展示内容分级为A、J、PI、W的内容。
提示:设置了AD_CONTENT_CLASSIFICATION_W后广告平台的返回的广告数量可能会少一些。
// 请求个性化广告与非个性化广告,当参数设置为ALLOW_ALL时,setHwNonPersonalizedAd方法和setThirdNonPersonalizedAd方法设置的个性化广告是有效的
RequestOptions requestOptions = HwAds.getRequestOptions();
requestOptions.toBuilder().setNonPersonalizedAd(ALLOW_ALL).build();
ALLOW_ALL:个性化广告与非个性化广告。ALLOW_NON_PERSONALIZED:非个性化广告。
// 华为DSP投放的广告设置个性化广告与非个性化广告
RequestOptions requestOptions = HwAds.getRequestOptions();
requestOptions.toBuilder().setHwNonPersonalizedAd(ALLOW_ALL).build();
ALLOW_ALL:个性化广告与非个性化广告。ALLOW_NON_PERSONALIZED:非个性化广告。
// 三方DSP投放的广告设置个性化广告与非个性化广告
RequestOptions requestOptions = HwAds.getRequestOptions();
requestOptions.toBuilder().setThirdNonPersonalizedAd(ALLOW_ALL).build();
ALLOW_ALL:个性化广告与非个性化广告。ALLOW_NON_PERSONALIZED:非个性化广告。
提示:设置了ALLOW_NON_PERSONALIZED后广告平台的返回的广告数量可能会少一些。
具体参数详情请查看HMS Core基于受众人群请求广告官网指南。
了解更多详情>>
访问华为开发者联盟官网
获取开发指导文档
华为移动服务开源仓库地址:GitHub、Gitee
关注我们,第一时间了解 HMS Core 最新技术资讯~
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s
我想使用spawn(针对多个并发子进程)在Ruby中执行一个外部进程,并将标准输出或标准错误收集到一个字符串中,其方式类似于使用Python的子进程Popen.communicate()可以完成的操作。我尝试将:out/:err重定向到一个新的StringIO对象,但这会生成一个ArgumentError,并且临时重新定义$stdxxx会混淆子进程的输出。 最佳答案 如果你不喜欢popen,这是我的方法:r,w=IO.pipepid=Process.spawn(command,:out=>w,:err=>[:child,:out])
我有一个使用SeleniumWebdriver和Nokogiri的Ruby应用程序。我想选择一个类,然后对于那个类对应的每个div,我想根据div的内容执行一个Action。例如,我正在解析以下页面:https://www.google.com/webhp?sourceid=chrome-instant&ion=1&espv=2&ie=UTF-8#q=puppies这是一个搜索结果页面,我正在寻找描述中包含“Adoption”一词的第一个结果。因此机器人应该寻找带有className:"result"的div,对于每个检查它的.descriptiondiv是否包含单词“adoption
我正在尝试提取方括号内的内容。到目前为止,我一直在使用它,它有效,但我想知道我是否可以直接在正则表达式中使用某些东西,而不是使用这个删除功能。a="Thisissuchagreatday[coolawesome]"a[/\[.*?\]/].delete('[]')#=>"coolawesome" 最佳答案 差不多。a="Thisissuchagreatday[coolawesome]"a[/\[(.*?)\]/,1]#=>"coolawesome"a[/(?"coolawesome"第一个依赖于提取组而不是完全匹配;第二个利用前瞻和
使用Ruby1.8.6/Rails2.3.2我注意到在我的任何ActiveRecord模型类上调用的任何方法都返回nil而不是NoMethodError。除了烦人之外,这还破坏了动态查找器(find_by_name、find_by_id等),因为即使存在记录,它们也总是返回nil。不从ActiveRecord::Base派生的标准类不受影响。有没有办法追踪在ActiveRecord::Base之前拦截method_missing的是什么?更新:切换到1.8.7后,我发现(感谢@MichaelKohl)will_paginate插件首先处理method_missing。但是will_pa
我试图像这样在我的测试用例中执行获取:request.env['CONTENT_TYPE']='application/json'get:index,:application_name=>"Heka"虽然,它失败了:ActionView::MissingTemplate:Missingtemplatealarm_events/indexwith{:handlers=>[:builder,:haml,:erb,:rjs,:rhtml,:rxml],:locale=>[:en,:en],:formats=>[:html]尽管在我的Controller中我有:respond_to:html,
我的测试尝试访问网页并验证页面上是否存在某些元素。例如,它访问http://foo.com/homepage.html并检查Logo图像,然后访问http://bar.com/store/blah.html并检查页面上是否出现了某些文本。我的目标是访问经过Kerberos身份验证的网页。我发现Kerberos代码如下:主文件uri=URI.parse(Capybara.app_host)kerberos=Kerberos.new(uri.host)@kerberos_token=kerberos.encoded_tokenkerberos.rb文件classKerberosdefini
我有这个字符串:auteur="comtedeFlandreetHainaut,Baudouin,Jacques,Thierry"我想删除第一个逗号之前的所有内容,即在这种情况下保留“Baudouin,Jacques,Thierry”试过这个:nom=auteur.gsub(/.*,/,'')但这会删除最后一个逗号之前的每个逗号,只保留“Thierry”。 最佳答案 auteur.partition(",").last#=>"Baudouin,Jacques,Thierry" 关于rub