Discourse 广告插件(Ads)

:discourse2: Summary Discourse Advertising allows the set up of advertisements on Discourse
:open_book: Install Guide This plugin is bundled with Discourse core. There is no need to install the plugin separately.

:warning: AD-BLOCKERS If you are running an ad-blocker in your browser or through a vpn, the contents of your /admin/plugins page may be blanked out. Disabling your adblocker, using an incognito tab, or whitelisting your site should prevent this issue.

Features

This is the officially supported Discourse ad plugin. Install and configure it to start serving ads on your Discourse forum.

The plugin supports the following ad platforms :

Configuration

Setting up House Ads

If you don’t want to use an external ad platform, but want to show your own ads, then House Ads are for you! Define your ads by going to the Admin section of your Discourse forum, and go to the Plugins section. On the left, you should see a link called “House Ads”.

Begin by creating your ads. Give each a short descriptive name and enter the html for each. Style them using a custom theme (Admin > Customize > Themes). Lastly, click the Settings button in the House Ads UI and choose which of your ads to show in each of the ad slots. The ads will start showing as soon as you add them to slots.

Configure Ads For Your Advertisement Platform

  • Navigate to the Admin section in your Discourse forum.
  • Click on Settings and a left vertical navigation bar should appear.
  • Choose your advertisement platform.
    • House Ads - if you want to create and serve ads from your Discourse instance.
    • Adsense - if using Adsense as your advertisement platform.
    • DFP - if using the DoubleClick for Publishers advertisement platform.
    • Carbon Ads - if using the Carbon Ads advertisement platform.
    • AdButler - if using the AdButler advertisement platform.
Input Your Details
  1. Add in your publisher ID - your publisher ID can be obtained from your ad platform and can also be found in your ad tag (see pictures below).
  2. Choose your trust level from the dropdown box. This will only display ads to users with a certain level of trust. For more details about trust levels go to the Plugin Features heading.
  3. Get the Advertisement Tag from your Ad Platform - see the images below to see what a tag looks like.
  4. Add parts of your ad code to Discourse’s site settings for the locations you wish your ad to appear. Refer to image for your ad platform to where parts of your ad tag should go. For more detail about where the ad will appear
  5. Choose Your Ad Size - this is the same size that you’ve put into your ad provider to create your ad. Go to the Plugin Features heading to see a list of supported Ad sizes.
Adsense Advertisement Tag to Discourse’s Site Settings

First, add the contents of your ads.txt file to your Discourse ads txt site setting. Then copy the following values to your Discourse settings:

DoubleClick for Publishers’ Advertisement Tag to Discourse’s Site Settings

Amazon Affiliates’ Advertisement Tag to Discourse’s Site Settings

Only for Product Link and Banner Ads.

Carbon Ads Script Tag to Discourse’s Site Settings

AdButler Ads Zone URL to Discourse’s Site Settings

:warning: This plugin only support AdButler “Standard Zones”. Text and VAST are not supported.

If you browse to a zone in the AdButler admin, then you can find the Publisher ID (PPPPPP) and the Zone ID (ZZZZZZ) in the URL of your browser’s address bar:

https://admin.adbutler.com/?ID=PPPPPP&p=textadzone.view&zoneID=ZZZZZZ

Configure the ads in Admin > Settings > AdButler. Enter the publisher id in the “adbutler publisher id” setting, and enter the Zone IDs in the different zone id settings as desired.

By default, ads are assumed to be size 728 x 90, or 320 x 50 in mobile view. To use different size ads, customize using CSS in your site’s theme. Override the following CSS:

.adbutler-ad { width: 728px; height: 90px; } .adbutler-mobile-ad { width: 320px; height: 50px; }

View Your Ad

Once you’ve configured your settings and your advertising platform has ads that are ready to serve, navigate to the page where you’ve inputted for the location and you should see ads.

Plugin Features

Available Locations for Ad Display

The following are available locations along with a description and an image showing their location within Discourse to display ads for all platforms.

Location Name Description
Topic List Top Ad will appear at the header of Discourse homepage
Topic Above Post Stream Ad will appear in the header of all Discourse forum topics
Topic Above Suggested Ad will appear in the footer above suggested topics of all Discourse forum topics
Post Bottom & Nth Post Ad will appear on the stipulated nth post within a topic. So if you have 5 posts in a topic and you want the ad to display after on the 2nd post, put 2 in ad_platform_nth_post_code .

Trust Levels

You can use the ad_platform_through_trust_level dropdown to disable ads for users above a certain trust levels. As a guide, choosing:

  • 0 shows ads to users that are not logged in.
  • 1 shows ads to users that are not logged in, and to new and basic users.
  • 2 shows ads to members as well, but not to regulars and leaders.
  • 3 shows ads to everyone, but not to leaders.
  • 4 shows ads to everyone including leaders.

To find more about trust levels in Discourse, refer to Discourse’s posts on trust levels

Personal messages

By default, ads won’t be shown in personal messages. To enable ads in personal messages, use the “no ads for personal messages” setting.

Groups

To give some users an ad-free experience, put the users in groups and add those groups to the “no ads for groups” setting.

Note that the Visibility in the group settings needs to be at least Group owners, members, moderators to ensure users who are part of the group can see that the group exists. If the Visibility of the group is more restrictive, the setting “no ads for groups” will be ignored and the ads will be visible to members of the group.

Categories

To disable ads in certain categories, add them to the “no ads for categories” setting. Also consider using the “no ads for restricted categories” to disable ads in all categories that have read access restrictions.

Tags

Individual topics can have ads disabled by using tags, and entering those tags in the “no ads for tags” setting. This is useful if some topics violate ad network policies.

:discourse2: Hosted by us? This plugin is available on our Standard, Business, and Enterprise plans. Advertising | Discourse - Civilized Discussion

Last edited by @david 2025-07-22T13:12:46Z

Check documentPerform check on document:
79 个赞

帖子已拆分为新主题:如何添加其他广告服务的广告代码?

广告拦截恢复支持 (AdSense)

Adsense 添加了效果相当不错的广告拦截恢复服务

问题是,如果我们有订阅者或赞助者,它并不知道这一点,所以会打扰他们。我们能否考虑添加对这个标签的支持,以便可以根据用户组启用/禁用它?:folded_hands:

这需要一个特殊的标签

1 个赞

最近将我的论坛更新到最新版本后,一些用户遇到了 JS 语法错误,看起来是来自 discourse 广告插件,特别是 house ad:

内容安全策略指南已过时。最新的是什么?

感谢提醒我需要更新OP。已完成。 :slight_smile:

我们很久以前就实施了strict-dynamic CSP,您应该不需要进行任何进一步的设置。

我们建议删除https:unsafe-inline,除非您出于特定原因需要它们,因为它们不能防止XSS漏洞。

1 个赞

你好

是否可以根据为注册表单创建的自定义用户字段(例如,性别=男/女,地点=美国/加拿大,婚姻状况=已婚/单身)向目标受众展示广告?

如果不行,是否正在考虑此功能,如果正在考虑,是否有预计完成时间?

此功能将允许在特定地点创建多个广告,但用户只能看到针对他们的广告。这将开辟更多的收入选择。

此致,

1 个赞

您好,

是否可以通过 API 创建和管理房屋广告?

此致

该插件不支持在首页展示广告。
就像被绑住手一样。
有没有办法在PC和移动端首页都显示广告?
顺便提一下:Discourse是用Docker安装的。

谢谢。

您好,以下位置对您不起作用吗?

谢谢您的回复。我好像没有看到您提到的选项。


已修改:主题列表顶部广告。但它无法在主页上显示广告。

1 个赞

:partying_face: 此插件现已作为 Discourse 核心的一部分进行捆绑,详情请参阅 Bundling more popular plugins with Discourse core app.yml 中移除。

3 个赞

我在管理部分、插件下拉菜单和管理搜索中都找不到该插件。

(Discourse 已更新,插件已从 app.yml 中移除)

您是否使用广告拦截器?

也许在所有站点设置中搜索该设置会有帮助。在那里过滤广告设置的术语是 plugin:discourse-adplugin

不,我使用的是 Brave 浏览器,并且关闭了 Shields。另外,我对新的管理菜单有点迷茫。

{Yourforum}/admin/site_settings/category/all_results?filter=plugin%3Adiscourse-adplugin 应该会带您进入设置,而无需使用菜单

未找到内容

1 个赞

插件似乎已重命名。

在我的网站上,我发现它位于 \u003cforum_url\u003e/admin/plugins/pluginad/house_creatives。也许是因为我除了 House Ads 之外不使用任何其他东西,所以这是我在侧边栏中看到的链接:

我认为“House Ads”部分仅与 House Ads 相关。其他广告设置没有自己的标签页。这就像“Calendar”和“Event”一样,“Calendar”在管理员侧边栏中只带您到一个管理节假日的页面——而不是与日历和事件插件相关的所有内容。

虽然大多数插件都有这个带有面包屑、名称、描述和设置标签页的页面,但有些插件仍然没有。此插件就是其中一个例子。

我仍然没有在管理菜单中找到该插件。肯定是因为它太显眼了,我才忽略了它。